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PREFACE 



This manual describes the functions of all CRAY X-MP computer systems 
currently manufactured by Cray Research, Inc. (CRI). For information on 
earlier models of the CRAY X-MP computer system, contact your local Cray 
representative . 

This manual is written for customers. It describes the overall design of 
the CRAY X-MP computer systems; provides basic information on the 
computation section, exchange mechanism, and functional units; and 
explains the symbolic machine instructions. A fact sheet for each 
CRAY X-MP model provides specific information pertaining to that model. 

This manual contains the following sections: 

Section Description 

1 Contains the introduction to this manual 

2 Describes the design of the CRAY X-MP CPU. The 
registers, functional units, and Exchange Package are 
described, and a block diagram is provided. 

3 Provides detailed information on the instructions that 
operate on the CRAY X-MP computer system. Each machine 
instruction can be represented symbolically in Cray 
Assembly Language (CAL). The instructions are listed in 
octal form in a box format that provides the CAL syntax 
format, an operand if required, a brief description of 
each instruction, and the machine instruction. 

A detailed description of the instruction and an example 
using the instruction follow the boxed information. 

4 Specific information for each of the current CRAY X-MP 
models is given, along with a photo and a maximum 
configuration drawing for each model. 

For the reader's convenience, a glossary is also included; it defines 
many of the commonly used Cray acronymns. 
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CENTRAL PROCESSING UNITS 

Each CPU has a computation section consisting of operating registers, 
functional units, and an instruction control network. The instruction 
control network makes all decisions related to instruction issue as well 
as coordinating the three types of processing (vector, scalar, or 
address). Each of the processing modes has its associated registers and 
functional units. In multiple-processor mainframes, the interprocessor 
section, which coordinates processing between CPUs and Central Memory, is 
shared. 

Refer to section 2 for more information on the computation section. 



INTERFACES 

The Cray mainframe is designed for use with front-end computers in a 
computer network. A front-end computer system is self contained and 
executes under the control of its own operating system. 

Standard interfaces connect the Cray mainframe's I/O channels to channels 
of front-end computers, providing input data to the Cray computer system 
and receiving output from it for distribution to peripheral equipment. An 
FEI compensates for differences in channel widths, machine word size, 
electrical logic levels, and control signals. The FEI is housed in a 
stand-alone cabinet (figure 1-2) located near the host computer. Its 
operation is transparent to both the front-end computer user and the Cray 
user. As an option, a 3-Mybte/s fiber-optic link (FOL-3) is available for 
any front-end interface to provide front-end connections of up to .621 
mile (1 km) and complete electrical separation from the Cray computer 
system. 

The High-speed External channel (HSX-1) is a 100-Mybte/s channel that 
connects a CRAY X-MP computer system to external equipment supplied by the 
customer. This channel can be used over distances of up to 70 ft (21.3 m) 
and can drive machines such as high-speed graphic devices. Refer to the 
specification sheets in section 4 for specific configuration information. 




Figure 1-2. Typical Interface Cabinet 
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I/O SUBSYSTEM 

The IOS, shown in figure 1-3, can have multiple I/O Processors (IOPS), a 
Buffer Memory, and required interfaces. It is designed for fast data 
transfer between front-end computers, peripheral devices, storage 
devices, and the IOS ' s Buffer Memory or between its Buffer Memory and the 
Central Memory of a Cray mainframe. The IOS is usually housed in its own 
stand-alone cabinet. For the CRAY X-MP/14se, however, the IOS is housed 
in the mainframe chassis; refer to the specification sheets in section 4 
for specific information. 

Various types of IOPs may be configured in an IOS: a Master IOP (MIOP), 
a Buffer IOP (BIOP), a Disk IOP (DIOP), or an Auxiliary IOP (XIOP). Each 
IOP controls different portions of the system; the number of IOPs is site 
dependent. 

Each IOP of the IOS has a memory section, a control section, a 
computation section, and an input/output (I/O) section. I/O sections are 
independent and handle some portion of the I/O requirements for the IOS. 
IOS hardware allows for simultaneous data transfers between the MIOP, 
BIOP, DIOP, or XIOP of the IOS and the mainframe's Central Memory. t 

Each IOP controls a different portion of the system. The MIOP controls 
the FEIs and the standard group of station** peripherals. It is 
connected to the Peripheral Expander; the Peripheral Expander contains 
controllers for peripheral devices. The MIOP is also connected to Buffer 
Memory and to the mainframe over a 6-Mbyte/s channel pair. The MIOP can 
control other functions on some systems, such as the HSX-1 channel 
interface; refer to the specification sheets in section 4 for more 
information. 

The BIOP is the main link between the mainframe's Central Memory and the 
mass storage devices. Data from mass storage is transferred through the 
BIOP's Local Memory to the mainframe's Central Memory through a 
100-Mbyte/s channel pair. The BIOP can control other functions on some 
systems; refer to the specification sheets in section 4 for more 
information. 

The DIOP is used for additional disk storage units (DSUs). The DIOP 
connects to Buffer Memory and to the mainframe Central Memory over a 
100-Mbyte/s channel pair. The DIOP data transfer sequence is similar to 
the BIOP's sequence. 



f Software supporting the 100-Mbyte/s channel pair to the XIOP and MIOP 

is currently not available, 
ft The term "station" means both hardware and software. The station is 

the link to the front end or can act as a limited front end (such as 

the MIOP) . 
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The XIOP is used for block multiplexer channels and interfaces to the 
block multiplexer controllers (BMCs). In most CRAY X-MP computer 
systems, the XIOP also interfaces with the HSX channel; refer to the 
specification sheets in section 4 for more information. 




Figure 1-3. I/O Subsystem Chassis 



DISK STORAGE UNITS 

For mass storage, the system uses CRI disk storage units (DSUs). A disk 
controller unit (DCU) interfaces the DSUs to an IOP within the IOS. 

The IOP and the disk controller unit can transfer data between the direct 
memory access (DMA) port of the IOP and multiple DSUs, without missing 
data or skipping revolutions, even when all DSUs are operating at full 
speed. 
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SOLID-STATE STORAGE DEVICE 

The SSD shown in figure 1-4 is an optional, high-performance device used 
for temporary data storage. It transfers data between the mainframe's 
Central Memory and the SSD through one or two special Cray interface 
cables with a maximum speed of 1000-Mbyte/s each. The actual speed of 
these transfers depends on the SSD and CRAY X-MP memory size and system 
configuration. The SSD can also be connected directly to an IOP over a 
100 -Mbyte/ s channel pair. 

The SSD-3I is a special version of the SSD; it is housed within the IOS 
chassis. Refer to section 4 for all the current SSD configurations 
available. 




Figure 1-4. Solid-state Storage Device Chassis 
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CONDENSING UNITS 

A condensing unit (figure 1-5) contains the major components of the 
refrigeration system used to cool the computer chassis. Heat is removed 
from the condensing unit by a second-level cooling system that is not 
part of the computer system. 





Figure 1-5. Condensing Unit 
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POWER DISTRIBUTION UNITS 

The mainframe, IOS, and SSD may have independent power distribution units 
(PDUs). Refer to section 4 for required number of PDU's needed for each 
model. 

The PDU for the mainframe contains adjustable transformers for regulating 
the voltage to each column of the mainframe. The PDU also contains 
temperature and voltage monitoring equipment that checks temperatures at 
strategic locations on the mainframe chassis. Automatic warning and 
shutdown circuitry protects the mainframe in case of overheating or 
excessive cooling. Control switches for the motor-generators and the 
condensing unit are also mounted on the mainframe's power distribution 
unit. 

A pair of PDUs perform similar functions for the IOS chassis and the SSD 
chassis. 

Figure 1-6 shows the power distribution units for the CRAY X-MP/4 
mainframe (left) and for the CRAY X-MP/1 and CRAY X-MP/2 mainframes, IOS, 
and SSD (right) . 
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Figure 1-6. Power Distribution Units 
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MOTOR -GENERATOR UNITS 

A motor-generator unit (figure 1-7) converts primary power from 
commercial power mains to the 400-Hz power used by the system. This unit 
also isolates the system from transients and fluctuations on the 
commercial power mains. The equipment consists of three motor-generator 
units. 




Figure 1-7. Motor-generator Equipment 
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CONVENTIONS 

This manual uses the following conventions: 

Convention Description 

lowercase Variable information 

italic 



(XX) 



Register bit 
designators 



X or x or x An ignored value 

n An unknown variable value 

The contents of a register designated by the Xx 
value 

Numbered right to left as powers of 2, designators 
starting with 2^. Exceptions are the Exchange 
Package and the Vector Mask register; Exchange 
Package bits are numbered from left to right and are 
numbered not as powers of 2 but as bits through 63, 
with bit as the most significant and bit 63 as the 
least significant. Vector Mask register bits 
correspond to a word element in a vector register. 
Bit 2^3 corresponds to element 0, bit 2^ 
corresponds to element 63. 

Unless otherwise indicated, numbers are decimal numbers. Octal numbers 
are indicated with an 8 subscript. Exceptions are register numbers, 
channel numbers, instruction parcels in instruction buffers, and 
instruction forms, which are given in octal without the subscript. 



EXAMPLES 



The following are examples of the preceding conventions. 



Examples 

Transmit (kk) to Si 



167ixk 



Description 

Transmit the contents of the A register 
specified by the k designator to the 
S register specified by the i 
designator. 

Machine instruction 167. The j 
register designator is not used and is 
an ignored value. 
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Examples Description 

Read n words from memory Read an unknown variable number of 

words from memory. You can read, 
within the stated restrictions, as few 
or many words from memory as you wish. 

Bit 2^3 of an S or The value represents the most 

element of a V register significant bit. 
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CRAY X-MP DESIGN DETAILS 



The following subsections describe the major components of a CRAY X-MP 
central processing unit (CPU). 



CPU COMPUTATION SECTION 

Each CPU is an identical, independent computation section consisting of 
operating registers, functional units, and an instruction control 
network (refer to figure 2-1, a fold-out block diagram of a typical CRAY 
X-MP computation section) . The computation section performs three types 
of processing: address, scalar, and vector. Address processing 
operates on internal control information, such as addresses and indexes, 
while scalar and vector processing are performed on data. The 
instruction control network makes all decisions related to instruction 
issue as well as coordinating the three types of processing. Each of 
the processing modes has its associated registers and functional units. 

Address information flows from Central Memory, instruction values or 
from control registers to address registers. Information in the address 
registers is distributed to various parts of the control network for use 
in controlling the scalar, vector, and I/O operations. The address 
registers can also supply operands to two integer functional units. The 
units generate address and index information and return the result to 
the address registers. Address information can also be transmitted to 
Central Memory from the address registers. 

Data flow in a computation section is from Central Memory to registers 
and from registers to functional units. Results flow from functional 
units to registers and from registers to Central Memory or back to 
functional units. Data flows along either the scalar or vector path, 
depending on the processing mode. An exception is that scalar registers 
can provide one required operand for some vector operations performed in 
the vector functional units. 

The computation section performs integer or floating-point arithmetic 
operations. Integer arithmetic is performed in twos complement mode. 
Floating-point quantities have signed magnitude representation. 

Floating-point instructions provide for addition, subtraction, 
multiplication, and reciprocal approximation. The reciprocal 
approximation instructions provide for a floating-point divide operation 
that uses a multiple instruction sequence. 
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Figure 2-1. CRAY X-MP Block Diagram 
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Integer or fixed-point operations are integer addition, integer 
subtraction, and integer multiplication. An integer multiply operation 
is done through a software algorithm using the floating-point multiply 
functional unit to generate multiple partial products. These partial 
products are then shifted and merged to form the full product. No 
integer divide instruction is provided; the operation is accomplished 
through a software algorithm using floating-point hardware. 

The instruction set includes Boolean operations for OR, AND, 
equivalence, and exclusive OR, and for a mask-controlled merge 
operation. Shift operations allow the manipulation of either 64-bit or 
128-bit operands to produce 64-bit results. With the exception of 
24-bit integer arithmetic, most operations are implemented in vector and 
scalar instructions. The integer product is a scalar instruction 
designed for index calculation. Full indexing capability lets you index 
throughout memory in either scalar or vector modes. The index can be 
positive or negative in either mode. Indexing allows matrix operations 
in vector mode to be performed on rows or on the diagonal as well as 
allowing conventional column-oriented operations. 

Population and parity counts are provided for both vector and scalar 
operations. An additional scalar operation is the leading zero count. 



PROGRAMMABLE CLOCK 

A programmable clock is a standard feature of the CRAY X-MP computer 
systems. This clock allows the operating system to force interrupts to 
occur at a particular time or frequency. The clock frequency/intervals 
vary for different models of the CRAY X-MP computer systems. 



REGISTERS 

A CPU has three primary and two intermediate sets of registers. The 
primary sets of registers are the address (A), scalar (S), and vector 
(V) registers. These registers are considered primary because 
functional units can access them directly. 

For the A and S registers, an intermediate level of registers exists. 
These registers are not accessible to the functional units but act as a 
buffer for the primary registers. Block transfers of consecutive 
locations are possible between these registers and Central Memory so 
that the number of memory reference instructions required for scalar and 
address operands is greatly reduced. The intermediate registers that 
support the A registers are referred to as intermediate address (B) 
registers. The intermediate registers that support S registers are 
referred to as scalar-save (T) registers. 
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Address registers 

The A registers serve a variety of applications but are primarily used 
as address registers for memory references and as index registers. They 
provide values for shift counts, loop control, and channel I/O 
operations and receive values of population count and leading zeros 
count. In address applications, A registers index the base address for 
scalar memory references and provide both a base address and an address 
increment for vector memory references. 

The B registers are used as intermediate storage for the A registers. 
Typically, B registers contain data to be referenced repeatedly over a 
long span, making it unnecessary to retain the data in either A 
registers or Central Memory. Examples of uses are loop counts, variable 
array base addresses, and dimensions. 



Scalar registers 

The S registers are the principal scalar registers for a CPU serving as 
the source and destination for operands executing scalar arithmetic and 
logical instructions. Scalar functional units perform both integer and 
floating-point arithmetic operations. 

The T registers are used as intermediate storage for the S registers. 
Data is transferred between T and S registers and between T registers 
and Central Memory. 



Vector registers 

The V registers are used for vector operations. Successive elements 
from a V register enter a functional unit in successive clock periods 
(CPs). The effective length of a vector register for any operation is 
controlled by the program-selectable Vector Length (VL) register. The 
Vector Mask (VM) register allows for the logical selection of particular 
elements of a vector. 



FUNCTIONAL UNITS 

Instructions other than simple transmits or control operations are 
performed by specialized hardware known as functional units. Each unit 
implements an algorithm or a portion of the instruction set. Most 
functional units can operate simultaneously. Functional units have 
independent logic except for the following: 

• The Reciprocal Approximation and Vector Population Count units 
share some logic. 
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• The Floating-point Multiply and Second Vector Logical units share 
input and output paths . 

• The Scalar Add and Scalar Shift units share output paths. 

The preceding cases of shared logic can cause a hold issue condition. 

All functional units perform algorithms in a fixed amount of time; 
delays are impossible once the operands have been delivered to the unit. 
Functional units are fully segmented. This means that a new set of 
operands for unrelated computation can enter a functional unit each CP, 
even though the functional unit time can be more than 1 CP. 

The functional units identified are arbitrarily described in four 
groups: address, scalar, vector, and floating-point. Each of the first 
three groups function with one of the primary register types (A, S, and 
V) to support the address, scalar, and vector modes of processing 
available in the mainframe. The fourth group, floating-point, supports 
either scalar or vector operations and accepts operands from or delivers 
results to S or V registers. In addition, Central Memory can also act 
as a functional unit for vector operations. 

A functional unit engaged in a vector operation remains busy until it is 
finished. In this state, the functional unit is reserved. Other 
instructions requiring the same functional unit are not issued until the 
previous operation is complete. Only one functional unit of each type 
is available to the vector instruction hardware (with the exception of 
the Second Vector Logical unit). When the vector operation completes, 
the reservation is dropped and the functional unit is then available for 
another operation. 



Address functional units 

Address functional units perform integer arithmetic on operands obtained 
from A registers and deliver the results to an A register (refer to 
section 2 for an explanation of integer arithmetic). The arithmetic is 
twos complement. 

Address Add functional unit - The Address Add functional unit performs 
integer addition and subtraction; addition and subtraction are performed 
in a similar manner. The unit detects no overflow. 

Address Multiply functional unit - The Address Multiply functional unit 
forms an integer product from two operands. No rounding is performed. 



Scalar functional units 

Scalar functional units perform operations on operands obtained from S 
registers and usually deliver the results to an S register (refer to 
section 2 for an explanation of integer arithmetic). The exception is 
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the Population/Parity/Leading Zero Count functional unit, which delivers 
its result to an A register. 

The Scalar Add, Scalar Shift, Scalar Logical, and Scalar 
Population/Parity/Leading Zero functional units are exclusively 
associated with scalar operations and are described here. Three 
additional functional units are used for both scalar and vector 
operations. They are described in the subsection on Floating-point 
Functional Units. 

Scalar Add functional unit - The Scalar Add functional unit performs 
integer addition and subtraction; addition and subtraction are performed 
in a similar manner. The unit detects no overflow. 

Scalar Shift functional unit - The Scalar Shift functional unit shifts 
the entire contents of an S register or shifts the contents of two 
concatenated S registers into a single resultant S register. 

Scalar Logical functional unit - The Scalar Logical functional unit 
performs bit-by-bit manipulation of quantities obtained from S 
registers. 

Scalar Population/Parity/Leading Zero functional unit - This functional 
unit can count the number of bits in an S register having a value of 1 
in the operand and returns a 1-bit population parity count (even 
parity) . It also can count the number of bits of preceding a 1 bit in 
the operand from left to right; the operand is obtained from an S 
register and the result is delivered to an A register. 



Vector functional units 

Most vector functional units perform operations on operands obtained 
from one or two V registers or from a V register and an S register. The 
Reciprocal, Shift, and Population/Parity functional units, which require 
only one operand, are exceptions. Results from a vector functional unit 
are delivered to a V register. 

Successive operand pairs are transmitted each CP to a functional unit. 
The corresponding result emerges from the functional unit n CPs later, 
where n is the functional unit time and is constant for a given 
functional unit. The VL register determines the number of operands or 
operand pairs to be processed by a functional unit. 

The functional units described in this subsection are exclusively 
associated with vector operations. Three functional units are 
associated with both vector operations and scalar operations and are 
described in the Floating-point Functional Units subsection. When a 
floating-point functional unit is used for a vector operation, the 
general description of vector functional units given in the subsection 
applies. 
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Vector Add functional unit - The Vector Add functional unit performs 
integer addition and subtraction for a vector operation and delivers the 
results to elements of a V register. Addition and subtraction are 
performed in a similar manner. The unit detects no overflow. 

Vector Shift functional unit - The Vector Shift functional unit shifts 
the entire contents of a V register element or the value formed from two 
consecutive elements of a V register. Shift counts are obtained from an 
A register and are end off with zero fill. 

Full Vector Logical functional unit - The Full Vector Logical functional 
unit performs a bit-by-bit manipulation of specified quantities for 
specific instructions. The Full Vector Logical functional unit also 
performs vector register merge, compressed index, and logical operations 
associated with the vector mask instruction. 

Second Vector Logical functional unit - The Second Vector Logical 
functional unit performs a bit-by-bit manipulation of the specified 
quantities for specific instructions. A selection is made as to which 
of the two vector logical functional units to use: the Full Vector 
Logical functional unit or the Second Vector Logical functional unit. 
If the Second Vector Logical unit is enabled (through the Exchange 
Package), instructions are issued there first if possible. If the unit 
is busy, issue is then attempted to the Full Vector Logical unit. When 
both units are busy, the first unit to clear is selected for issue. 
Instructions are issued to the Full Vector Logical unit first, even 
though the Second Vector Logical unit is not busy, if another conflict 
is present for the Second Vector Logical unit (for example, a 
Floating-point Multiply functional unit reservation). 

Vector Population/Parity functional unit - The Vector Population/Parity 
functional unit counts the 1 bits in each element of the source V 
register. The total number of 1 bits is the population count. This 
population count can be an odd or an even number, as shown by its 
low-order bit. The vector population count instruction delivers the 
total population count to elements of the destination V register while 
the vector population count parity instruction delivers the low-order 
bit of the count to the destination V register for even parity. 



Floating-point functional units 

Three floating-point functional units perform floating-point arithmetic 
for scalar and vector operations. When a scalar instruction is 
executed, operands are obtained from S register (s) and results are 
delivered to an S register. For most vector instructions, operands are 
obtained from pairs of V registers, or from an S register and a V 
register. Results are delivered to a V register. An exception is the 
Reciprocal Approximation unit, which requires only one input operand. 

Floating-point Add functional unit - The Floating-point Add functional 
unit performs addition or subtraction of operands in floating-point 
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format. The final result is normalized even when operands are 
unnormalized. Normalized numbers are explained later in this section. 

Floating-point Multiply functional unit - The Floating-point Multiply 
functional unit executes instructions that provide for full- and 
half-precision multiplication of operands in floating-point format and 
for computing two minus a floating-point product for reciprocal 
iterations. 

The half-precision product is rounded; the full-precision product can be 
rounded or not rounded. 

Input operands are assumed to be normalized. The Floating-point 
Multiply functional unit delivers a normalized result only if both input 
operands are normalized. Normalized numbers are explained later in this 
section. 

Out-of-range exponents are detected. If both operands have zero 
exponents, however, the result is considered as an integer product, is 
not normalized, and is not considered out of range. 

Reciprocal Approximation functional unit - The Reciprocal Approximation 
functional unit finds the approximate reciprocal of an operand in 
floating-point format. The input operand is assumed to be normalized 
and, if so, the result is correct. The high-order bit of the 
coefficient is not tested but is assumed to be a 1. Out-of-range 
exponents are detected. Normalized numbers are explained later in this 
section. 



CPU CONTROL SECTION 

The CPU's control section contains instruction buffers and registers for 
instruction issue and control. The following subsections describe the 
registers and buffers. 



Instruction buffers 

Each CPU has four instruction buffers; each holds 128 consecutive 
instruction parcels. Instruction parcels are held in the buffers before 
being delivered to the NIP or LIP registers. 



Program Address (P) register 

The P register indicates the next parcel of program code to enter the 
Next Instruction Parcel (NIP) register. New data enters the P register 
on an instruction branch or on an exchange sequence. The contents of P 
are then advanced sequentially until the next branch or exchange 
sequence. 
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Next Instruction Parcel (NIP) register 

The NIP register holds a parcel of program code before it enters the 
Current Instruction Parcel (CIP) register. 



Current Instruction Parcel (CIP) and Lower Instruction Parcel (LIP) 
registers 

The CIP register holds the instruction waiting to be issued. If the 
instruction is a 2-parcel instruction, the CIP register holds the first 
parcel of the instruction and the LIP register holds the second parcel. 
Instruction formats are explained in section 3. 



EXCHANGE SEQUENCE 

A CPU uses an exchange mechanism for switching instruction execution from 
program to program. This exchange mechanism involves the use of blocks 
of program parameters known as Exchange Packages and a CPU operation 
referred to as an exchange sequence. 

Instruction issue is terminated by the hardware upon detection of an 
interrupt condition. All memory bank and functional unit activity is 
allowed to finish. To switch execution in order to handle the interrupt, 
the CPU executes the exchange sequence. This causes program parameters 
for the next program to be exchanged with current information in the 
operating registers. Each program in the system has its associated 
16-word Exchange Package, which contains the parameters used in its 
execution sequence. Only the A and S registers are saved in a program's 
Exchange Package; the contents of the B, T, V, VM, Shared Address (SB), 
Shared Scalar (ST), and Semaphore (SM) registers must be saved by 
software. 

Exchange sequences may be initiated by a deadstart sequence or program 
exit, voluntarily by the software, or automatically upon occurrence of an 
interrupt condition. 



EXCHANGE PACKAGE 

The Exchange Package is a block of sixteen 64-bit words in memory 
associated with a particular program. The Exchange Package contains the 
basic parameters necessary to provide continuity from one execution 
interval for the program to the next. The exchange sequence swaps data 
from memory to the operating registers and back to memory. This sequence 
exchanges data in an active Exchange Package residing in the operating 
registers with an inactive Exchange Package in memory. The Exchange 
Address (XA) register address of the active Exchange Package specifies 
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the memory address to be used for the swap. Data is exchanged and a new 
program execution interval is initiated by the exchange sequence. 

The following subsections define the contents of the Exchange Package. 



Processor number (PN) 

The state of the PN in the Exchange Package indicates in which CPU the 
Exchange Package executed. This value is not read into the CPU; it is a 
constant inserted only into a package being stored. In single-processor 
models, this value is always 0. 



Memory error data 

Error data, consisting of four fields of information, appears in the 
Exchange Package if the interrupt on correctable memory error bit is set 
and a correctable memory error is encountered or if the interrupt on 
uncorrectable memory error bit is set and an uncorrectable memory error 
is detected. * 

Memory error data fields are described below. 



Field 

Error type (E) 

Syndrome ( S ) 
Read mode (R) 



Description 

The type of memory error encountered, correctable 
or uncorrectable, is indicated in this word of the 
Exchange Package. 

The S bits used in defining a memory data error 
are returned in this word of the Exchange Package. 

The type of read mode in progress when a memory 
data error occurred is indicated in these bits of 
the Exchange Package. 



Read address (CSB) The chip select, bank, and section bits where a 

memory data error occurred are defined in this 
word. 



Program Address (P) register 

The P register contents (address of first program instruction not yet 
issued) are stored in this word of the Exchange Package. The instruction 
at this location is the first instruction to be issued when this program 
begins again. 



f For multiple-bit memory errors, the hardware always sets the 

Correctable Memory Error flag in the interrupted Exchange Package. 
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Instruction Base Address (IBA) register 

The IBA register holds the base address of the user's instruction field. 
A user instruction can be executed only by the CPU if the absolute 
address at which the instruction is located is greater than or equal to 
the contents of the current Exchange Package IBA register of the program 
executing. This determination is made at instruction buffer fetch time 
by the CPU. 



Instruction Limit Address (ILA) register 

The ILA register holds the limit address of the user's instruction 
field. A user instruction can be executed only by the CPU if the 
absolute address at which the instruction is located is less than the 
contents of the current Exchange Package ILA register of the program 
executing. This determination is made at instruction buffer fetch time 
by the CPU. 



Mode (M) register 

The M register contains part of the Exchange Package for a currently 
active program. The bits of the M register that are set selectively 
during an exchange sequence are defined as follows: 

• Waiting for Semaphore (WS) flag; when set, the CPU exchanged when 
a test and set instruction was holding in the CIP register. 

• Floating-point Error Status (FPS) flag; when set, a floating-point 
error has occurred regardless of the state of the Floating-point 
Error Mode flag. 

• Bidirectional Memory Mode (BDM) flag; when set, block reads and 
writes can operate concurrently. 

• Selected for External Interrupts (SEI) flag; when set, this CPU is 
preferred for I/O interrupts.' 

• Interrupt Monitor Mode (IMM) flag; when set, it enables all 
interrupts in monitor mode except PC, MCU, I/O, NEX, and ICP. 

• Operand Range Error Mode (IOR) flag; when set, it enables 
interrupts on operand address range errors. 

• Correctable Memory Error Mode (ICM) flag; when set, it enables 
interrupts on correctable memory data errors. 



f Not available on single-processor systems 
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♦ 



• 



• 



Floating-point Error Mode (IFP) flag; when set, it enables 
interrupts on floating-point errors. 

Uncorrectable Memory Error Mode (IUM) flag; when set, it enables 
interrupts on uncorrectable memory data errors. 

Monitor Mode (MM) flag; when set, it inhibits all interrupts 
except memory errors, normal exit, and error exit. 



Vector Not Used (VNU) position 

The state of the VNU position in the Exchange Package indicates whether 
several specific vector instructions were issued during the execution 
intervals. If none of the instructions were issued, the bit is set. If 
one or more of the instructions were issued, the bit is not set. 



Enable Second Vector Logical (ESVL) position 

The contents of the ESVL position in the Exchange Package indicate 
whether or not the Second Vector Logical unit can be used. If set, the 
Second Vector Logical unit may be used. If clear, the Second Vector 
Logical unit cannot be used; only the Full Vector Logical unit may be 
used. 



Flag (F) register 

The F register contains part of the Exchange Package for the currently 
active program. This register contains flags individually identified 
within the Exchange Package. Setting any of these flags interrupts 
program execution. When one or more flags are set, a Request Interrupt 
signal is sent to initiate an exchange sequence. The F register contents 
are stored along with the rest of the Exchange Package. The monitor 
program can analyze the flags for the cause of the interruption. Before 
the monitor program exchanges back to the package, it must clear the 
flags in the F register area of the package. If any bit remains set, 
another exchange occurs immediately. 

The F register contains the following flags: 



• 



• 



Interrupt from Internal CPU (ICP) flag; set when the other CPU 
issues instruction 0014J1. * 

Deadlock (DL) flag; set when all CPU(s) in a cluster are holding 
issue on a test and set instruction. 



f Not available on single-processor systems 
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• Programmable Clock Interrupt (PCI) flag; set when the interrupt 
countdown counter in the programmable clock equals 0. 

• MCU Interrupt (MCU) flag; set when the MIOP sends this signal. 

• Floating-point Error (FPE) flag; set when a floating-point range 
error occurs in any of the floating-point functional units and the 
Enable Floating-point Interrupt flag is set. 

• Operand Range Error (ORE) flag; set when a data reference is made 
outside the boundaries of the DBA and DLA registers and the Enable 
Operand Range Interrupt flag is set. 

• Program Range Error (PRE) flag; set when an instruction fetch is 
made outside the boundaries of the Instruction Base Address (IBA) 
and Instruction Limit Address (ILA) registers. 

• Memory Error (ME) flag; set when a correctable or uncorrectable 
memory error occurs and the corresponding enable memory error mode 
bit is set in the M register. 

• I/O Interrupt (IOI) flag; set when a 6-Mbyte/s channel or the 
1000-Mbyte/s (100 Mbyte/s channel in single-procession models) 
channel completes a transfer. 

• Error Exit (EEX) flag; if not in MM, set by an error exit 
instruction. 

• Normal Exit (NEX) flag; if not in MM and IMM, set by a normal exit 
instruction. 



Exchange Address (XA) register 

The XA register specifies the first word address (FWA) of a 16-word 
Exchange Package loaded by an exchange operation. The register contains 
the high-order 8 bits of a 12-bit field specifying the address. The 
low-order bits of the field are always 0; an Exchange Package must begin 
on a 16-word boundary. The 12 -bit limit requires that the absolute 
address be in the lower 4096 (10,0003) wor< * s of memory. When an 
execution interval terminates, the exchange sequence exchanges the 
contents of the registers with the contents of the Exchange Package at 
the beginning address (XA) in memory. 



Vector Length (VL) register 

The VL register specifies the length of all vector operations performed 
by vector instructions and the length of the vectors held by the V 
registers. 
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Enhanced Addressing Mode (EAM) position * 

The contents of the EAM position in the Exchange Package indicates 
whether or not address extension occurs for address calculations. 



Data Base Address (DBA) register 

The DBA register holds the base address of the user's data field. An 
operand can be fetched or stored only by the CPU if the absolute address 
at which the operand is located is greater than or equal to the contents 
of the current Exchange Package DBA register of the program executing. 
This determination is made each time an operand is fetched or stored by 
the CPU. 



Program State (PS) register 

The state of the PS register is manipulated by the operating system to 
represent different program states in the CPUs concurrently processing a 
single program. 



Cluster Number (CLN) register 

The CLN register determines the CPU's cluster. The CLN register contents 
are used to determine which set of SB, ST, and SM registers the CPU can 
access. If the CLN register is 0, the CPU does not have access to any 
SB, ST, or SM register. The CLN register's contents in all CPUs are also 
used to determine the condition necessary for a deadlock interrupt. 



Data Limit Address (DLA) register 

The DLA register holds the upper limit address of the user's data field. 
An operand can be fetched or stored only by the CPU if the absolute 
address at which the operand is located is less than the contents of the 
current Exchange Package DLA register of the program executing. This 
determination is made each time an operand is fetched or stored by the 
CPU. 

If the final absolute address of the operand as computed by the CPU does 
not fall between the range of addresses contained within the currently 
executing Exchange Package DBA and DLA registers, the CPU generates an 
operand (address) range error interrupt. 



t Not available on all systems 
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A registers 

The current contents of all A registers are stored in a portion of the 
Exchange Package. 



S registers 

The current contents of all S registers are stored in a portion of the 
Exchange Package. 



CPU INTERCOMMUNICATION 

The inter-CPU communication section of the mainframe contains clusters of 
shared registers for interprocessor communication and synchronization. 
Each cluster consists of Shared Address (SB), Shared Scalar (ST), and 
Semaphore (SM) registers. 

In multiprocessor systems, the SB and ST registers are used for passing 
address and scalar information from one CPU to another, while the SM 
registers are used for control between CPUs. In single-processor 
systems, the CPU can use the SB and ST registers, while the SM registers 
can be used by the CPU for storage and control. 

Each CPU's Cluster Number (CLN) register determines which set of shared 
registers is accessed by a CPU (clustering). The cluster may be accessed 
by any processor to which it is allocated in either user or system 
(monitor) mode. Any processor in monitor mode can interrupt any other 
and cause it to switch from user to monitor mode. Additionally, each 
processor in a cluster can asynchronously perform scalar or vector 
operations dictated by user programs. The hardware also provides 
built-in detection of system deadlock within the cluster. 



REAL-TIME CLOCK 

In multiprocessor systems, the mainframe contains one real-time clock 
(RTC), which is shared by all the CPUs. This counter is 64-bits and 
advances one count each CP. Because the clock advances synchronously 
with program execution, it can be used to time the program to an exact 
number of CPs. In single-processor systems, the RTC is not shared but 
works the same way. 



ARITHMETIC OPERATIONS 

Functional units in a CPU perform either twos complement integer 
arithmetic or floating-point arithmetic. 
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Integer arithmetic 

All integer arithmetic, whether 24 bits or 64 bits, is twos complement 
and is represented in the registers as shown in figure 2-2. The Address 
Add and Address Multiply functional units perform 24-bit arithmetic. The 
Scalar Add and the Vector Add functional units perform 64-bit arithmetic. 



Twos Complement Integer (24 bits) 
2 23 2 



Sign 

Twos Complement Integer (64 bits) 
2 63 



Sign 



Figure 2-2. Integer Data Formats 



Multiplication of two scalar (64-bit) integer operands is accomplished by 
using the floating-point multiply instruction and one of the two methods 
that follow. The method used depends on the magnitude of the operands 
and the number of bits to contain the product. 

If the operands are nonzero only in the 24 least significant bits, the 
two integer operands can be multiplied if each is shifted 24 bits to the 
left before the multiply operation. (The Floating-point Multiply 
functional unit recognizes the conditions in which both operands have 
zero exponents as a special case.) The Floating-point Multiply 
functional unit returns the high-order 48 bits of the product of the 
coefficients as the coefficient of the result and leaves the exponent 
field as 0. Refer to figure 2-6. If the operand coefficients were 
generated by a means other than shifting so the low-order 24 bits would 
be nonzero, the low-order 48 bits of the product could be nonzero, and 
the high-order 48 bits (the return part) could be one larger than 
expected because truncation compensation constant is always added during 
a multiply. 

If the operands are greater than 24 bits, multiplication is done by 
software forming multiple partial products and then shifting and adding 
the partial products. 
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Division is done by algorithm; the particular algorithm used depends on 
the number of bits in the quotient. The quickest and most frequently 
used method is to convert the numbers to floating-point format and then 
use the floating-point functional units. 



Floating-point arithmetic 

Floating-point numbers are represented in a standard format throughout 
the CPU. This format is a packed representation of a binary coefficient 
and an exponent (power of 2). The coefficient is a 48-bit signed 
fraction. The sign of the coefficient is separated from the rest of the 
coefficient as shown in figure 2-3. Because the coefficient is of signed 
magnitude, it is not complemented for negative values. 



.63 o62 



Binary Point 
2 48T 2 47 



Coeff. 
Sign 



Exponent 



Coefficient 



Figure 2-3. Floating-point Data Format 



The exponent portion of the floating-point format is represented as a 
biased integer in bits 2 62 through 2 4 ^. The bias that is added to 
the exponents is 40000g. The positive range of exponents is 40OOO3 
through 577773. The negative range of exponents is 37777g through 
20000g. Thus, the unbiased range of exponents is the following (the 
negative range is one larger): 

2-20000 8 through 2 +17777 8 

In terms of decimal values, the floating-point format of the system 
allows the accurate expression of numbers to about 15 decimal digits in 
the approximate decimal range of io~ 24 ^ 6 through 10 +24 ^ 6 . 

Figure 2-4 and the following steps show the relationship between the 
bias, exponent, and coefficient. To convert the number to its decimal 
equivalent: 

1. Subtract the bias from the exponent to get the integer value of 
the exponent 

-40000 
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2. Multiply 2 raised to the integer value of the exponent by the 

normalized coefficient, expressed as a fraction, to get the result 

2 1 x 0.4 8 = 1.0 



2 63 2 62 



Binary Point 
2 48T 2 47 






40001 


4000000000000000 



Coeff. Exponent 
Sign 



Normalized Coefficient 



Figure 2-4. Internal Representation of Floating-point Number (Octal) 



A value or an underflow result is not biased and is represented as a 
word of all zeros. 

A negative is not generated by any floating-point functional unit, 
except in the case in which a negative is one operand going into the 
Floating-point Multiply or Floating-point Add functional unit. 

The remainder of this subsection describes normalized floating-point 
numbers, floating-point range errors, double-precision numbers, and the 
addition, multiplication, and division algorithms. 



Normalized floating-point numbers 

A nonzero floating-point number is normalized if the most significant bit 
of the coefficient is nonzero. This condition implies that the 
coefficient has been shifted as far left as possible and that the 
exponent has been adjusted accordingly; therefore, the floating-point 
number has no leading zeros in the coefficient. The exception is that a 
normalized floating-point zero is all zeros. 

When a floating-point number is created by inserting an exponent of 
4OO6O3 and a 48-bit integer word into the coefficient the result should 
be normalized before being used in a floating-point operation. 
Normalization is accomplished by adding the unnormalized floating-point 
operand to 0. Since SO provides a 64-bit zero when used in the Sj 
field of an instruction, an operand in Sk is normalized with the 
062 iOk instruction. Si, which can be Sk, contains the normalized 
result. 

The 170i0fc instruction normalizes Vk into Vi. 
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Floating-point range errors 

Overflow of the floating-point range is indicated by an exponent value of 
60000 8 for Floating-point Add or Multiply and 60002 8 for 

Floating-point Reciprocal or greater in packed format. Detection of the 
overflow condition initiates an interrupt if the Floating-point Mode flag 
is set in the Mode register and monitor mode is not in effect. The 
Floating-point Mode flag can be set or cleared by a user mode program. 

Cray operating system COS keeps a bit in a table to indicate the 
condition of the mode bit. System software manipulates the mode bit and 
uses the table bit to indicate how the mode should be left for the user. 
Therefore, the user usually needs to put the appropriate bit in the table 
if the user changes the mode. 

Floating-point range error conditions are detected by the floating-point 
functional units, as described in the following paragraphs. 

Floating-point Add functional unit - A floating-point add range error 
condition is generated for scalar operands when the larger incoming 
exponent is greater than or equal to 60000g. This condition sets the 
Floating-point Error flag, with an exponent of 6OOOO3 being sent to the 
result register along with the computed coefficient, as in the following 
example: 

60000 .4xxxxxxxxxxxxxxx Range Error 
+57777 .4 xxxxxxxxxxxxxxx 

60000 . 6xxxxxxxxxxxxxxx Result Register 



NOTE 

If a floating-point add or subtract generates an 
exponent of less than 20OOO3 or a coefficient of 0, 
the condition is considered an underflow; no fault is 
generated, and the word returned from the functional 
unit is all bits. If either operand is out of bounds 
(exponent of 6OOOO3 or greater) or if the final sum 
or difference is out of bounds (exponent of 6OOOO3 or 
greater), the exponent is set to 6OOOO3, and a 
floating-point error is flagged. If floating-point 
faults are enabled, an interrupt occurs. Refer to the 
Floating-point Range Errors subsection for more 
information. 
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Floating-point Multiply functional unit - Whether or not out-of-range 

conditions occur the way they are handled can be determined by using the 

exponent matrix shown in figure 2-5. The exponent of the result, for any 

set of exponents, falls into one of seven unique zones. A description of 
each zone follows. 



NOTE 
Only zones 6 and 7 can generate floating-point faults 

Exponent of Operand 1 



& 




77777 



1043 



Figure 2-5. Exponent Matrix for Floating-point Multiply Unit 
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Zone Description 

(l) This indicates a simple integer multiply; no fault is 
possible. 

(T) These exponents would result in an underflow condition. It 
is flagged as such, and the result is set to +0. (Multiply 
by is in this group.) 

\3J Underflow may occur on this boundary. When a normalize 

shift is required, the underflow is not detected/ and the 
coefficient and the exponent are not zeroed out. The 
exponent used before the shift is 2OOOO3; the exponent 
used after the shift is 17777 8 . Underflow detection is 
done on the exponent used for an unshifted product 
coefficient. 

(4) The use of an operand with an underflow exponent is allowed 
if the final result is within the range 2OOOO3 to 57777g. 

(¥) This is the normal operand range, and normal results are 
produced. 

QT) Overflow is flagged on this boundary. If a normalized 

shift is required, the value should be within bounds with a 
577773 exponent. Because overflow is detected, however, 
a 6OOOO3 is inserted in the product as the final exponent 
when the exponent for the unnormalized shift condition is 
used. 

(Y) Within this zone, an overflow fault is flagged and the 
product exponent is set to 6OOOO3. 

Out-of-range conditions are tested before normalizing in the 
Floating-point Multiply functional unit. As shown, if both incoming 
exponents are equal to 0, the operation is treated as an integer 
multiply. The result is treated normally with no normalization shift of 
the result allowed. The result is a 48-bit quantity starting with 
bit 2 47 . When using this feature, the operands should be considered as 
24-bit integers in bits 2 47 through 2 24 . In figure 2-6, if operand 1 
is 4 and operand 2 is 6, a 48-bit result of 3O3 is produced. Bit 2^3 
obeys the usual rules for multiplying signs and the result is a sign and 
magnitude integer. The form of integers (refer to figure 2-2) accepted 
by the integer add and subtract and expected by the software is twos 
complement, not sign and magnitude; therefore, negative products must be 
converted. 
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If bits 2^ through 2^3 i n operands 1 and 2 of figure 2-6 have any 
1 bits, the product might be 1 (2^) too large because a truncation 
compensation constant is added during the multiply process. (The 
following paragraphs discuss the truncation constant and its use.) The 
size of the shaded area in operands 1 and 2 (figure 2-6) does not need to 
be the same for both operands. To get a correct product, the only 
requirement is that the sum of the number of bits in the shaded area be 
48 bits or more. If the sum is more than 48 bits, the binary point in 
the product is the number of places to the left that the sum is in excess 
of 48 (assuming that the operand binary points are at the left boundary 
of the shaded areas). 



Operand 1 



2 63 




2 47 2 


23 2 




0—0 


04 


Must be to ensure 
correct product 



Sign 



Operand 2 



0—0 






—06 



WmM; 



be 



correct product 



to 



ensure 



Sign 



Result 



0—0 



-030 



Sign 



Figure 2-6. Integer Multiply in Floating-point Multiply 
Functional Unit 



Floating-point Reciprocal Approximation functional unit - For the 
Floating-point Reciprocal Approximation functional unit, an incoming 
operand with an exponent less than or equal to 200OI3 or greater than 
or equal to 60002g causes a floating-point range error. The error flag 
is set and an exponent of 60000g and the computed coefficient with 



,47 



set to are sent to the result register. 



Double-precision numbers 

The CPU does not provide special hardware for performing double- or 
multiple-precision operations. Double-precision computations with 95-bit 
accuracy are available through software routines provided by CRI. 
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Addition algorithm 

Floating-point addition or subtraction is performed in a 49-bit register 
(figure 2-7). Trial subtraction of the exponents selects the operand to 
be shifted down for aligning the operands. The larger exponent operand 
carries the sign. The coefficient of the number with the smaller 
exponent is shifted right to align with the coefficient of the number 
with the larger exponent. Bits shifted out of the register are lost; no 
roundup occurs. If the sum carries into the high-order bit, the 
low-order bit is discarded and an appropriate exponent adjustment is 
made. All results are normalized and if the result is less than the 
machine minimum, the error is suppressed. 



48 



Discarded 



Figure 2-7. 49-bit Floating-point Addition 



The Floating-point Add functional unit normalizes any floating-point 
number within the format of the mainframe's floating-point number 
system. The functional unit right shifts 1 or left shifts up to 48 per 
result to normalize the result. 

One zero operand and one valid operand can be sent to the Floating-point 
Add functional unit, and the valid operand is sent through the unit 
normalized. Concurrently, the functional unit checks for overflow and/or 
underflow; underflow results are not flagged as errors. 



Multiplication algorithm 

The Floating-point Multiply functional unit has the two 48-bit 
coefficients as input into the functional unit. If the coefficients are 
both normalized, a full product is either 95 bits or 96 bits, depending 
on the value of the coefficients. A 96-bit product is normalized as 
generated. A 95-bit product requires a left shift of one to generate the 
final coefficient. If the shift is done, the final exponent is reduced 
by 1 to reflect the shift. 

The following discussion and the power of two designators used assumes 
that the product generated is in its final form; that is, no shift was 
required. 
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On the system, the functional unit truncates part of the low-order bits 
of the 96-bit product. To adjust for this truncation, a constant is 
unconditionally added above the truncation. The average value of this 
truncation is 9.2 5 x 2~56 / which was determined by adding all carries 
produced by all possible combinations that could be truncated and 
dividing the sum by the number of possible combinations. Nine carries 
are injected at the 2~56 position to compensate for the truncated bits. 

The effect of the truncation without compensation is at most a result 
coefficient 1 smaller than expected. With compensation, the results 
range from 1 too large to 1 too small in the 2~ 48 bit position, with 
approximately 99 percent of the values having zero deviation from what 
would have been generated had a full 96-bit product been present. The 
multiplication is commutative; that is, A times B equals B times A. 

Rounding is optional where truncation compensation is not used. The 
rounding method used adds a constant so that it is 50 percent high (0.25 
x 2~ 48 ; high) 38 percent of the time and 25 percent low (0.125 x 
2~ 48 ; low) 62 percent of the time, resulting in a near-zero average 
rounding error. In a full-precision rounded multiply, 2 round bits are 
entered into the functional unit at bit positions 2~50 and 2~51 an( j 
allowed to propagate. 

For a half-precision multiply, round bits are entered into the functional 
unit at bit positions 2~^ 2 and 2~ 31 . A carry resulting from this 
entry is allowed to propagate up and the 29 most significant bits of the 
normalized result are transmitted back. 

The variations due to this truncation and rounding are in the following 
range: 

-0.23 x 2" 48 to +0.57 x 2~ 48 

or 

-8.17 x 10" 16 to +20.25 x 10" 16 

With a full 96-bit product and rounding equal to one-half the least 
significant bit, the following variation would be expected: 

-0.5 x 2" 48 to +0.5 x 2" 48 



Division algorithm 

The system performs floating-point division through reciprocal 
approximation, facilitating hardware implementation of a fully segmented 
functional unit. Because of this segmentation, operands enter the 
reciprocal unit during each CP. In vector mode, results are produced at 
a 1-CP rate and are used in other vector operations during chaining 
because all functional units in the system have the same result rate. 
The reciprocal approximation is based on Newton's method. 
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Newton ' s method - The division algorithm is an application of Newton's 
method for approximating the real roots of an arbitrary equation, 
F(x) = 0/ for which F(x) must be twice dif ferentiable with a continuous 
second derivative. The method requires an initial approximation (guess), 
xq, sufficiently close to the true root, x t , being sought (refer to 
figure 2-8). For a better approximation, a tangent line is drawn to the 
graph of y = F(x) at the point (xq, F(xq)). The X intercept of this 
tangent line is the better approximation x^. This can be repeated 
using x^ to find X2* and so on. 



y=F(x) 



(x .f(x Q )) 




1044 
Figure 2-8. Newton's Method 

Derivation of the division algorithm 

A definition for the derivative F'(x) of a function F(x) at point x t is 

F'(x t ) = limit F(x) - F(x t ) 

x ~* x t x " x t 

if this limit exists. If the limit does not exist, F(x) is not 
dif ferentiable at point t. 

For any point x^ near x^, 

~. , x F(x. ) - F(xi-) , . , , 

F (x t ) ~ i ^_ where ~ means approximately equal to. 

x i " x t 

This approximation improves as x^ approaches x t . Let x^ stand for 
an approximate solution and let x t stand for the true answer being 
sought. The exact answer is then the value of x that makes F(x) equal 
0. This is the case when x=x t , therefore F(x t ) in the equation above 
can be replaced by 0, giving the following approximation: 
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F'(x*-) ~ F(«i) 

c ~ Approximation (1) 

x i" x t 

x t - x^ is the correction applied to an approximate answer, x^, to give 
the right answer because x^ + (x t - x^) equals x t . Solving approximation 
(1) for (x t - x^) gives the following: 



X*- - Xi = CO 



rrection z - F ( x i' , 



F'(x t ) 

that is, - F ( x j) is the approximate correction. 
F'(x t ) 

If this quantity is substituted into the approximation, then: 

x t ~ ( x i + approximate correction) = x^ + ^. 

This gives the following equation: 

x. „=x.£( x )i , Equation (1) 
l + l l 

F'( Xi ) 

where x^ + ^ is a better approximation than x^ to the true value, x t , 
being sought. The exact answer is generally not obtained at once because 
the correction term is not generally exact. The operation is repeated 
until the answer becomes sufficiently close for practical use. 

To make use of Newton's method to find the reciprocal of a number B, 
simply use F(x) = (1/x - B) . 

First calculating F'(x) where: 

F'(x) = ( - - B)' = ( =$)' F ° r anY P ° int X l * °' 
X x^ 

1 1 

F'(x ) = — - Choosing for x, a value near 



1 
and applying equation (1), 

I_ - B 

x l 
Xn = Xi - x 



1' x 2 * ' - '- ~ B 



2 = x l " -=x- 



2 

X l 

2 1 
x = x + x ( — - B), 

^ 1 x l 

2 D 
x„ = x„ + x„ - x„B, 
2 111 

2 
x^ = 2x„ - x.B = x„(2 - x B). 
2 11 11 
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Done in reciprocal unit 



On the system, x^ times the quantity in parentheses is performed by a 
floating-point multiply. 2-x^B is performed by the reciprocal 
approximation instruction, x^ is the x near 1/B and is formed by the 
half-precision reciprocal approximation instruction. 

This approximation technique using Newton's method is implemented in the 
system. A hardware table lookup provides an initial guess, xq, to 
start the process. 

xq(2 - xqB) 1st approximation, II 

x^(2 - x^B) 2nd approximation, 12 

X2(2 - X2B) 3rd approximation, 13 

X3(2 - X3B) 4th approximation Done with software 

The system's Reciprocal Approximation functional unit performs three 
iterations: II, 12, and 13. II is accurate to 8 bits and is found after 
a table lookup to choose the initial guess, xq. 12 is the second 
iteration and is accurate to 16 bits. 13 is the final (third) iteration 
answer of the Reciprocal Approximation functional unit, and its result is 
accurate to 30 bits. 

A fourth iteration uses a special instruction within the Floating-point 
Multiply functional unit to calculate the correction term. This 
iteration is used to increase accuracy of the reciprocal unit's answer to 
full precision. A fifth iteration should not be done. 

The division algorithm that computes S1/S2 to full precision requires the 
following operations: 

Operation Performed By 

53 = 1/S2 Reciprocal Approximation functional unit 

54 = (2 - (S3 * S2)) Floating-point Multiply functional unit in 

iteration mode 

55 = S4 * S3 Floating-point Multiply functional unit using 

full-precision; S5 now equals 1/S2 to 48-bit 
accuracy. 

56 = S5 * SI Floating-point Multiply functional unit using 

full-precision rounded 

The reciprocal approximation at step 1 is correct to 30 bits. An 
additional Newton iteration (fourth iteration) at operations 2 and 3 
increases this accuracy to 48 bits. This iteration answer is applied as 
an operand in a full-precision rounded multiply operation to obtain the 
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quotient accurate to 48 bits. Additional iterations should not be 
attempted because erroneous results are possible. 



******************************************************* 

CAUTION 

The reciprocal iteration is designed for use once with 
each half-precision reciprocal generated. If the 
fourth iteration (the programmed iteration) results in 
an exact reciprocal or if an exact reciprocal is 
generated by some other method, performing another 
iteration results in an incorrect final reciprocal. 

******************************************************* 



Where 29 bits of accuracy are sufficient, the reciprocal approximation 
instruction is used with the half-precision multiply to produce a 
half -precision quotient in only two operations. 

Operation Performed By 

S3 = 1/S2 Reciprocal Approximation functional unit 

S6 = SI * S3 Floating-point Multiply functional unit in 

half -precis ion 

The 19 low-order bits of the half-precision results are returned as zeros 
with a rounding applied to the low-order bit of the 29-bit result. 

Another method of computing division is as follows: 

Operation Performed By 

53 = 1/S2 Reciprocal Approximation functional unit 

55 = SI * S3 Floating-point Multiply functional unit 

54 = (2 - (S3 * S2)) Floating-point Multiply functional unit 

56 = S4 * S5 Floating-point Multiply functional unit 

A scalar quotient is computed in a certain number of CPs because 
operations 2 and 3 issue in successive CPs. With this method, the 
correction to reach a full-precision reciprocal is applied after the 
numerator is multiplied times the half-precision reciprocal rather than 
before. 
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A vector quotient using this procedure requires less than four vector 
times because operations 1 and 2 are chained together. This overlaps one 
of the multiply operations. (A vector time is 1 CP for each element in 
the vector. ) 



******************************************************* 

CAUTION 

The coefficient of the reciprocal produced by the 
alternative method can be different by as much as 2 x 
2~48 f rom the first method described for generating 
full-precision reciprocals. This difference can occur 
because one method can round up as much as twice while 
the other method may not round at all. One round can 
occur while the correction is generated and the second 
round can occur when producing the final quotient. 

Therefore, if the reciprocals are to be compared, the 
same method should be used each time the reciprocals 
are generated. Cray Fortran CFT uses a consistent 
method and ensures that the reciprocals of numbers are 
always the same. 

******************************************************* 



LOGICAL OPERATIONS 

Scalar and vector logical units perform bit-by-bit manipulation of 64-bit 
quantities. Operations provide for forming logical products, 
differences, sums, and merges. 

A logical product is the AND function: 

Operand 1 10 10 
Operand 2 110 
Result 10 

A logical sum is the inclusive OR function: 

Operand 1 10 10 
Operand 2 110 
Result 1110 
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A logical difference is the exclusive OR function: 

Operand 1 10 10 
Operand 2 110 
Result 110 

A logical equivalence is the exclusive NOR function: 

Operand 1 10 10 
Operand 2 110 
Result 10 1 

The merge uses two operands and a mask to produce results as follows: 

Operand 1 10101010 

Operand 2 11001100 

Mask 11110000 

Result 10101100 

The bits of operand 1 pass where the mask bit is 1. The bits of operand 
2 pass where the mask bit is 0. 



CENTRAL MEMORY 

The CRAY X-MP Central Memory is shared by the CPUs on multiprocessor 
systems and is arranged in interleaved banks. The interleaved memory 
banks enable extremely high transfer rates through the I/O section and 
provide low read/write times for vector processing. All banks can be 
accessed independently and in parallel during each machine clock period. 

Each CRAY X-MP processor has four parallel memory ports: three for 
vector and scalar operations and one for I/O. The multiport memory has 
built-in conflict resolution hardware to minimize delays and maintain the 
integrity of all memory references to the same bank at the same time. 

All CRAY X-MP models provide a flexible hardware chaining mechanism for 
vector processing. This feature enables a result vector to be used at 
any time as an operand in a succeeding operation. Also, vector chaining 
to and from memory is possible. 

In addition, the CRAY X-MP computer system provides hardware support for 
vector conditionals. Gather/scatter operations (chainable from other 
vector memory fetches and stores) and compressed-index generation 
facilitate and speed execution of various conditional vector operations 
realized from ordinary user programs. All models allow execution of two 
vector logical operations of the same type at the same time. 

Central Memory comes in various sizes; refer to section 4 for the 
different memory configurations. 
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INPUT/OUTPUT SECTION 

The I/O section is shared by the CPUs in multiprocessor systems and may 
be equipped with a variety of high-performance channels for communicating 
with the mainframe, the IOS, and the SSD. The latter two devices are 
high-speed data transfer devices designed to support CRAY X-MP processing 
speeds. Refer to section 4 for information on channel types and transfer 
rates for your specific CRAY X-MP computer system. 
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CRAY X-MP SYMBOLIC MACHINE 
INSTRUCTIONS 



Each CRAY X-MP mainframe machine instruction can be represented 
symbolically in Cray Assembly Language (CAL). This section provides 
information on the symbolic machine instructions used with the CRAY X-MP 
computer systems. 

This section provides information on symbolic machine instruction format 
for a 1-parcel (16-bit) instruction or a 2-parcel (32-bit) instruction. 
It also describes special register values that may be referenced by the 
instructions and the symbolic notation used for coding the machine 
instructions. 

Detailed information on the CAL instructions that operate on the CRAY 
X-MP computer systems is provided in the Machine Instruction Description 
subsection. Each machine instruction begins with boxed information 
consisting of the CAL syntax format, an operand if required, a brief 
description of each instruction, and the machine instruction. 

Following the boxed information is a detailed description of the 
instruction and an example. 

The Symbolic Instruction Summary section provides a summary of functional 
units and the symbolic machine instructions; the Functional Instruction 
Summary section lists the instructions by function. 



INSTRUCTION SYNTAX 

The assembler identifies a symbolic instruction according to its syntax 
and generates a corresponding binary machine code. An instruction is 
generated in the assembly section in use when the instruction is 
interpreted. 

This section describes the format of symbolic machine instructions, 
special register values, and notation used for coding symbolic machine 
instructions for CAL Assembler Version 2 on a CRAY X-MP computer system, 



INSTRUCTION FORMAT 

Each instruction is either a 1-parcel (16-bit) instruction or a 2-parcel 
(32-bit) instruction. Instructions are packed 4 parcels per word. 



HR-3005 3-1 



Parcels are numbered through 3 from left to right and any parcel 
position can be addressed in branch instructions. A 2-parcel instruction 
begins in any parcel of a word and can span a word boundary. For 
example, a 2-parcel instruction beginning in parcel 3 of a word ends in 
parcel of the next word. No padding to word boundaries is required. 
Figure 3-1 illustrates the general form of instructions. 



First Parcel Second Parcel 



h i j k m 



| 4 | 3 1 3 | 3 | 3 | 16 | Bits 

Figure 3-1. General Form for Instructions 

Four variations of this general format use the fields differently. The 
formats of the following variations are described in this section: 

• 1-parcel instruction format with discrete j and k fields 

• 1-parcel instruction format with combined j and k fields 

• 2-parcel instruction format with combined j, k, and m fields 

• 2-parcel instruction format with combined i, j, k, and m 
fields 

1-parcel instruction format with discrete j and k fields 

The most common of the 1-parcel instruction formats uses the i, j, and 
k fields as individual designators for operand and result registers (see 
figure 3-2). The g and h fields define the operation code. The i 
field designates a result register and the j and k fields designate 
operand registers. Some instructions ignore one or more of the i, j, 
and k fields. The following types of instructions use this format: 

• Arithmetic 

• Logical 

• Double shift 

• Floating-point constant 
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g h i j k 

1 4 | 3 | 3 | 3 I 3 I Bits 

Operation Register 

Code Designators 



Figure 3-2. 1-parcel Instruction Format with 
Discrete j and k Fields 



1-parcel instruction format with combined j and k fields 

Some 1-parcel instructions use the j and k fields as a combined 6-bit 
field (see figure 3-3). The g and h fields contain the operation code, 
and the i field is generally a destination register. The combined j and 
k fields generally contain a constant or a B or T register designator. 
The branch instruction 005 and the following types of instructions use 
the 1-parcel instruction format with combined j and k fields: 



Constant 

B and T register block memory transfer 

B and T register data transfer 

Single shift 

Mask 



j* 



1.1 



3 I 



| Bits 



Operation Constant or 

Code Register 

Result Designator 
Register 



Figure 3-3. 1-parcel Instruction Format with 
Combined j and k Fields 



2-parcel instruction format with combined j, k, and m fields 

The instruction type for a 22-bit immediate constant uses the combined 
J, k, and m fields to hold the constant. The 7 -bit g and h fields 
contain an operation code, and the 3-bit i field designates a result 
register. The instruction type using this format transfers the 22-bit 
jkm constant to an A or S register. 



HR-3005 



3-3 



The instruction type used for Scalar Memory transfers also requires a 
22-bit jkm field for an address displacement. This instruction type 
uses the 4-bit g field for an operation code, the 3-bit h field to 
designate an address index register, and the 3-bit i field to designate 
a source or result register. (Refer to the Special Register Values 
subsection. ) 

Figure 3-4 shows the two general applications for the 2-parcel 
instruction format with combined J, k, and m fields. 



MOTE 

When an immediate constant with both relocatable and 
parcel attributes is used, the result of the relocation 
will be incorrect if the loader-determined actual 
address (within the user's field length) is greater 
than 1,048,575. This is because the resulting 
relocated value has more than 22 significant bits. A 
CAL caution message is issued if this occurs. The 
exception to this is when Aft exp executes on a 
CRAY X-MP computer system model 48 or 416. 



First Parcel Second Parcel 



m 



I 3 1 3 | 22 | Bits 



\ 



Operation Result Constant 
Code Register 



First Parcel Second Parcel 



| 4 | 3 | 3 | 22 | Bits 



Operation! \ Address or 
Code / \ Displacement 

Address \ Source or 
Register Result Register 
Used as Index 



Figure 3-4. 2-parcel Instruction Format with 
Combined j, k, and m Fields 
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2-parcel instruction format with combined i, j, k, and m fields 

The 2-parcel branch instruction type uses the combined i, j, k, and 
m fields to contain a 24-bit address that allows branching to an 
instruction parcel (see figure 3-5). A 7-bit operation code (gh) is 
followed by an ijkm field. The high-order bit of the i field is 
equal to 0. 



First Parcel 



Second Parcel 



m 



Operation 
Code 



22 



Address 



12 | Bits 



Parcel 
Select 



Figure 3-5. 2-parcel Instruction Format with 
Combined i, j, k, and m Fields 



The 2-parcel instruction type for a 24-bit immediate constant (figure 
3-6) uses the combined i, j, k, and m fields to hold the constant. 
This instruction type uses the 4-bit g field for an operation code and 
the 3-bit h field to designate the result address register. The 
high-order bit of the i field is set. 



First Parcel 



Second Parcel 



m 



1 4 | 3 HI 



24 



| Bits 



Operation 
Code 



A * 



High 
Bit Set 



Constant 



Result 
Register 



Figure 3-6. 2-parcel Instruction Format for a 24-bit Immediate 
Constant with Combined i, j, k, and m Fields 
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SPECIAL REGISTER VALUES 

If the SO and AO registers are referenced in the j or k fields of 
certain instructions, the contents of the respective register are not 
used; instead, a special operand is generated. The special operand is 
available regardless of existing AO or SO reservations (and in this case 
is not checked) . This use does not alter the actual value of the SO or 
AO register. If SO or AO is used in the i field as the operand, the 
actual value of the register is provided. CAL issues a caution-level 
error message for AO or SO when does not apply to the i field. 
Table 3-1 shows the special register values. 



Table 3-1. Special Register Values 





Operand 


Field 


Value 


Ah, h=0 





Ai, i=0 


(AO) 


AJ, j=0 





hk, k=0 


1 


Si, i=0 


(SO) 


Sj, j=0 





Sk, k=0 


2 63 



SYMBOLIC NOTATION 

The following information describes the notation used for coding symbolic 
machine instructions. CAL contains two syntax forms: general and 
special. 



General syntax 

Register designators and the location, result, operand, and comment 
fields have the following general syntax requirements. 

Register designators - A, B, SB, S, T, ST, SM, and V registers can be 
referenced with numeric or symbolic designators. The symbolic 
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designators can be entered in uppercase, lowercase, or any mixture of 
upper and lowercase. 

In symbolic notation, the h, i, j, and k designators indicate the 
field of the machine instruction into which the register designator 
constant or symbol value is placed. An expression (exp) occupies the 
jk, ijk, jkm, or ijkm field depending on the operation code and 
magnitude of the expression value. Supporting registers have the 
following designators: 



Designator 


Register 


CA 


Current Address 


CL 


Channel Limit 


CI 


Channel Interrupt flag 


CE 


Channel Error flag 


RT 


Real-time Clock 


MC 


Master Clear 


SB 


Sign Bit (S/c, with k=0) 


SM 


Semaphore 


VL 


Vector Length 


VM 


Vector Mask 


XA 


Exchange Address 


Location field - 


- The location field of a s 



address as indicated by the current value of the location counter after 
any reguired force to parcel boundary occurs. 

Result field - The result field of a symbolic machine instruction can 
consist of one, two, or three subfields separated by commas. A subfield 
can be null or it can contain a register designator or an expression. 
The expression specifies a memory address that indicates the register or 
memory location to receive the results of the operation. The result 
field may contain a mnemonic indicating the function being performed (for 
example, J for jump or ex for exit) . The mnemonics are case sensitive 
and must be entered in either all uppercase or all lowercase letters; 
they cannot be mixed. For example, EX is a valid mnemonic for exit, 
while Ex is not. 

Operand field - The operand field of a symbolic machine instruction 
consists of no subfield or one, two, or three subfields separated by 
commas. A subfield can be null, contain an expression (with no register 
designators), or consist of register designators and operators. 
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The following special characters can appear in the operand field of 
symbolic machine instructions and are used by the assembler in 
determining the operation to be performed. 

Character Operation 

+ Arithmetic sum of specified registers 

Arithmetic difference of specified registers 

* Arithmetic product of specified registers 
/ Reciprocal of approximation 

# Use ones complement 

> Shift value or form mask from left to right 

< Shift value or form mask from right to left 

& Logical product of specified registers 

! Logical sum of specified registers 

\ Logical difference of specified registers 

In some instructions, register designators are prefixed by the following 
letters which have special meaning to the assembler. These letters can 
be entered in either uppercase or lowercase (case insensitive). 

F Floating-point operation 

H Half-precision floating-point operation 

R Rounded floating-point operation 

I Reciprocal iteration 

P Population count 

Q Parity count 

Z Leading-zero count 

Comment field - The comment field of the symbolic machine instructions 
begins in column 35. By convention, the comment should be preceded by a 
semicolon (;) in column 35, and a space. 



Special syntax forms 

The CAL instruction repertoire has been expanded for the convenience of 
programmers and to allow for special forms of symbolic instructions. 
Because of this expansion, certain Cray machine instructions can be 
generated from two or more different CAL instructions. For example, both 
of the following instructions generate instruction 002000, which causes a 
1 to be entered into the VL register: 

VL A0 
VL 1 

The first instruction is the basic form of the Enter VL instruction, 
which takes advantage of the special case in which (A7c)=l if k=Q; the 
second instruction is a special syntax form providing the programmer with 
a more convenient notation for the special case. 
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Any of the operations performed by special instructions can be performed 
by instructions in the basic set. Instructions having a special syntax 
form are identified as such in the instruction description found later in 
this section. 

In several cases, a single syntax form of an instruction can result in 
any of several different machine instructions being generated. These 
cases provide for entering the value of an expression into an A register 
or into an S register or for shifting S register contents, the assembler 
determines which instruction to generate from characteristics of the 
expression. 



MONITOR MODE INSTRUCTIONS 

The monitor mode instructions (channel control, set real-time clock, and 
programmable clock interrupts) perform specialized functions that are 
useful to the operating system. These instructions execute only when the 
CPU is operating in monitor mode. If an instruction is executed while 
the CPU is not in the monitor mode, it is treated as a no-op. 



MACHINE INSTRUCTION DESCRIPTIONS 

This section contains detailed information about individual instructions 
or groups of related instructions. Each instruction begins with boxed 
information consisting of the CAL syntax format. It consists of a result 
field description, an operand field description, a brief description of 
each instruction, and the machine instruction (octal code sequence 
defined by the gh fields). The appearance of an m in a format 
description designates an instruction consisting of two parcels. An x 
in the format description signifies that the field containing the x is 
ignored during a CRAY X-MP computer system instruction execution. CAL 
inserts a for each occurrence of x. 

Following the boxed information is a detailed description of the 
instruction or instructions and an example using the instruction. 



******************************************************* 

CAUTION 

Instructions with g, h, i, j, k, and m fields not 
explicitly described in the following instructions may 
produce indeterminate results. 

******************************************************* 
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INSTRUCTION 000 



| | | Machine 
Result | Operand | Description | Instruction 


ERR | | Error exit | 000000 



The 000 instruction is treated as an error condition and an exchange 
sequence occurs. The contents of the instruction buffers are voided by 
the exchange sequence. If monitor mode is not in effect, the Error Exit 
flag in the Flag (F) register is set. All instructions issued before 
this instruction are run to completion. 

When the results of previously issued instructions have arrived at the 
operating registers, an exchange occurs to the Exchange Package 
designated by the contents of the Exchange Address (XA) register. The 
program address stored in the Exchange Package on the terminating 
exchange sequence is advanced by 1 parcel from the address of the error 
exit instruction. 

The error exit instruction is not generally used in program code. This 
instruction is used to halt execution of an incorrectly coded program 
that branches to an unused area of memory or into a data area. 

The expression in the operand field is optional and has no effect on 
instruction execution; the low-order 9 bits of the expression value are 
placed in the ijk fields of the instruction. 



Example: 



Code Generated 



| Location | Result 



I 
1000000 



u= 



I1L 



I Operand 
■ 20 



Comment 
35 



ERR 
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INSTRUCTION 0010 



III | Machine | 
| Result | Operand | Description | Instruction | 


| CA,Ajt | A* | Set the Current Address (CA) | 0010J& | 
| | | register, for the channel | | 
| | | indicated by (Aj), to (kk) | | 
| | | and activate the channel | | 

| PASstt | | Pass I 001000 | 



f Privileged to monitor mode 
ft Special CAL syntax 



The 0010J& instruction sets the Current Address (CA) register for the 
channel indicated by the contents of Aj to the value specified in kk. 
It then activates the channel. 

Before this instruction is issued, the Channel Limit (CL) register should 
be initialized. As the transfer progresses, the address in CA is 
increased. When the contents of CA equals the contents of CL, the 
transfer is complete for the words at the initial address in CA through 1 
less than the address in CL. 

If not in monitor mode or when the j designator is or when the 
contents of Aj is less than 2 or greater than 25, the instruction 
executes as a pass instruction. When the k designator is 0, CA is set 
to 1. 



Example: 



ICode Generated 


Location | Result 


| Operand 


Comment 


1 


1 110 


120 


35 


1 

1001035 

1 


1 

|CA,A3 

1 


1 

|A5 

1 




1 
1001000 


1 
|PASS 


1 
1 
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INSTRUCTION 0011 



| | | Machine 
Result | Operand | Description | Instruction 


CL,Ajt | Ak | Set the channel (Aj) limit | 0011J& 
| | address to (Ak) \ 



•f* Privileged to monitor mode 



The OOlljk instruction sets the Channel Limit (CL) register for the 
channel indicated by the contents of A_7 to the address specified in Ak. 

The instruction is usually issued before issuing the CA,Aj Ak 
instruction. 

If not in monitor mode or when the j designator is or when the 
contents of Aj is less than 2 or greater than 25, the instruction is 
executed as a pass instruction. When the k designator is 0, CL is set 
to 1. 



Example: 



| Code Generated 

I 



001134 



| Locationl Result 



1L 



HO 

I 

|CL,A3 



| Operand 
120 



A4 



Comment 
35 
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INSTRUCTION 0012 



| | | Machine | 
Result | Operand | Description | Instruction | 


CI,Ajt | | Clear Channel (Aj) Interrupt | 0012 JO | 
1 1 flag I | 

MC,Aj | | Clear Channel (Aj) Interrupt | 0012 jl | 
| | flag and Error flag; set device | | 
| | master-clear (output channel); | | 
| | clear device ready-held | | 
| | (input channel). | | 



f Privileged to monitor mode 



Instruction 0012J0 clears the Interrupt flag and Error flag for the 
channel indicated by the contents of Aj. 

If not in monitor mode or when the j designator is or when the 
contents of Aj is less than 2 or greater than 25, the instruction is 
executed as a pass instruction. 

Instruction 0012J1 sets the device Master Clear. If (Aj) represents 
an output channel, the master clear is set; if (Aj) represents an input 
channel, the ready flag is cleared. 



Example: 



Code Generated 


Location| Result 


Operand 


Comment 




1 110 


20 


35 


001210 


|CI,A1 






001241 


| MC , A4 






001201 


|MC,A0 
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INSTRUCTION 0013 



| | | Machine 
Result | Operand | Description | Instruction 


XAt | aj* | Enter XA register with (Aj) | 0013 j'O 



f Privileged to monitor mode 



The 0013J0 instruction transmits bits 12 through 19 of register Aj to 
the Exchange Address (XA) register. 

If the j designator is 0/ the XA register is cleared. 

A monitor program activates a user job by initializing the XA register to 
point to the user job's Exchange Package and then executing a normal exit 
(EX). 



Example: 



I Code Generated 



1 Location | Result 



I Operand 



Comment 



1L 



ijsl 



2SL 



.25- 



1001350 



IXA 



A5 



NOTE 



Instruction 0013 is privileged to monitor mode and is 
treated as a pass instruction if the monitor mode bit 
is not set. 
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INSTRUCTION 0014 









Machine | 


Result 


Operand 


Description 


Instruction | 


RT 


SJ 


Enter RTC with (Sj) 


00 14 JO | 


SIPit 


exp 


Set interprocessor interrupt 
request of CPU exp; 0_<exp<^3 


0014J1 | 


SIPit ft 




Set interprocessor interrupt 
request 


001401 | 


CIPit 




Clear interprocessor interrupt 


001402 | 


CLNt ttt 


exp 


Cluster number = exp 
where 0_^exp£5 


0014J3 | 


PClH 


SJ 


Set program interrupt interval 


0014J4 | 


cci^ 




Clear clock interrupt 


001405 | 


ECI^f 




Enable clock interrupts 


001406 | 


DCI^f 




Disable clock interrupts 


001407 | 



f CRAY X-MP computer systems with multiple CPUs. This instruction is 
available when the numeric trait NUMCPUS, which is specified on the 
CPU parameter of the CAL invocation statement, is greater than 1. 

ft Special CAL syntax 

f'ft This instruction is available when the numeric trait NUMCLSTR, 
which is specified on the CPU parameter of the CAL invocation 
statement, is greater than zero. 

1f This instruction is available through the logical trait PC 

specified on the CPU parameter of the CAL invocation statement. 



NOTE 



Instruction 0014 is privileged to monitor mode and is 
treated as a pass instruction if the monitor mode bit 
is not set. 
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INSTRUCTION 0014 (continued) 



The 0014J0 instruction transmits the contents of register Sj to the 
Real-time Clock register. When the J designator is 0, the Real-time 
Clock register is set to 0. 

The 001401 and 001402 instructions handle interprocessor interrupt 
requests. When the k designator is 1, the instruction sets the internal 
CPU interrupt request in another CPU. If the other CPU is not in monitor 
mode/ the ICP (Interrupt from Internal CPU) flag sets in the F register, 
causing an interrupt. The request remains until cleared by the receiving 
CPU. 

When the k designator is 2, the instruction clears the internal CPU 
interrupt request set by another CPU. 

The 0014J3 instruction sets the cluster number to J to make the following 
cluster selections: 

CLN = No cluster; all shared register and semaphore operations are 
no-ops, (except SB, ST, or SM register reads, which return a 
value to hi or Si). 

CLN = 1 Cluster 1 

CLN = 2 Cluster 2 

CLN = 3 Cluster 3 

CLN = 4 Cluster 4 

CLN = 5 Cluster 5 

Each of clusters 1, 2, 3, 4, and 5 has a separate set of SM, SB, and ST 
registers. 

The 0014J4 instruction loads the low-order 32 bits from the Sj register 
into the Interrupt Interval register (II) and the Interrupt Countdown 
counter (ICD). The Interrupt Countdown counter is a 32-bit counter that 
is decreased by 1 each clock period until the contents of the counter is 
equal to 0. At this time, the real-time clock (RTC) interrupt request is 
set. The counter is then set to the interval value held in the Interrupt 
Interval register and repeats the countdown to cycle. When an RTC 
interrupt request is set, it remains set until a clear clock interrupt 
(CCI) instruction is executed. 

The 001405 instruction clears an RTC interrupt. 
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INSTRUCTION 0014 (continued) 



The 001406 instruction enables RTC interrupts at a rate determined by the 
value in the Interrupt Interval (II) register. 

The 001407 instruction disables RTC interrupts until an enable clock 
interrupt (ECI) instruction is executed. 



Example: 



Code Generated 



Location 



Result 



Operand 



Comment 



2SL 



2SL 



25_ 



001420 

001400 
001401 



001402 



001403 
001413 
001423 
001433 
001434 



001405 



001406 



001407 



RT 

RT 
SIPI 



CIPI 



CLN 
CLN 
CLN 
CLN 
PCI 



CCI 



ECI 



DCI 



S2 

SO 

1 





1 

2 
3 

S3 



; Set clock to 

; low-order 32 

; bits 

; Set clock to 

; Set 

; interprocessor 

; interrupt 

; request 

; Clear 

; interprocessor 

; interrupt 

; request 



; Load the 

; low-order 32 

; bits from (S3) 

; to (II) 

; Clear clock 

; interrupt 

; Enable clock 

; interrupt 

; Disable clock 

; interrupt 
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INSTRUCTION 0015 











Machine 


Result 


Operand 


Description 




Instruction 






Select performance monitor 




0015JO 






Set maintenance read mode 




001501 






Load diagnostic checkbyte 




001511 






with SI 










Set maintenance write mode 


1 


001521 






Set maintenance write mode 


2 


001531 



NOTE 



The 0015 instructions are not supported by CAL at this 
time. 



Instruction 0015J0 selects one of four groups of hardware related events 
to be monitored by the performance counters. 

Instructions 001501 through 001531 check the operation of the modules 
concerned with SECDED and to verify error detection and correction. 

Instructions 001501 and 001521 verify check bit memory storage. 
Instructions 001511 and 001531 verify error detection and correction. 
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INSTRUCTION 0020 



















Machine 


Result 


Operand 






De 


scription 


Instruction 


VL 


A* 




Transmit 


(A*) 


to 


VL 


002007c 


VLt 


1 




Enter 


1 . 


Into 


VL 




002000 



f Special CAL syntax 



Instruction 00200* and its special form (002000) enter the low-order 7 
bits of the contents of register kk into the VL register. 

The contents of the VL register determines the number of operations 
performed by a vector instruction. Since a vector register has 64 
elements, from 1 to 64 operations can be performed. The number of 
operations is (VL) modulo 64. When (VL) is 0, the number of operations 
performed is 64. 

In this publication/ a reference to register Vi implies operations 
involving the first n elements where n is the vector length unless a 
single element is explicitly noted as in the instructions Si Vj,A& and 
Vi,A* Sj. 

Vector operations controlled by the contents of VL begin with element 
of the vector registers and operate on consecutive elements. 



Examples: 

In the first example, if (A3) =6 then (VL)=6 following instruction 
execution and subseguent vector instructions operate on elements 
through 5 of vector registers. 



|Code Generated 


I Location | Result 


| Operand 


| Comment 


1 


11 110 


120 


135 



1002003 



|VL 



A3 
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INSTRUCTION 0020 (continued) 



In the second example, since the k designator is assembled as 0, (VL)=1 
and vector instructions operate on only one element, element 0. 



| Code Generated | Location) Result | Operand | Comment 

■ II HO 120 135 

I III I 

1002000 | |VL |1 | 



Lastly, if (A5)=0, then (VL)=64 and vector instructions operate on all 64 
elements of the vectors. 



| Code Generated | Location | Result | Operand | Comment 

■ II HO 120 135 

I III I 

1002005 I IVL IA5 I 
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INSTRUCTIONS 0021 - 0027 











Machine 


Result 


Operand 


Description 




Instruction 


EFI 




Enable floating-point interrupt 


002100 


DFI 




Disable floating-point interr 


upt 


002200 


ERlt 




Enable interrupt on address 
range error 




002300 


DRlt 




Disable interrupt on address 
range error 




002400 


DBMtt 




Disable bidirectional memory 
transfers 




002500 


EBMtt 




Enable bidirectional memory 
transfers 




002600 


CMRtt 




Complete memory references 




002700 



f This instruction is available through the logical trait CORI 

specified on the CPU parameter of the CAL invocation statement, 

ff This instruction is available through the logical trait BDM 

specified on the CPU parameter of the CAL invocation statement, 



The EFI and DFI instructions provide for setting and clearing the 
Floating-point Interrupt flag in the Mode register. These instructions 
do not check the previous state of the flag. 



******************************************************* 

CAUTION 

The operating system may have status bits reflecting 
whether interrupts on floating-point range errors are 
enabled or disabled. Such software status bits need to 
be modified to agree with the Floating-point Mode flag. 

******************************************************* 
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INSTRUCTIONS 0021 - 0027 (continued) 



The ERI and DRI instructions set and clear the Operand Range Mode flag in 
the Mode register. The two instructions do not check the previous state 
of the flag. When set, the Operand Range Mode flag enables interrupts on 
operand address range errors. 

The DBM and EBM instructions disable and enable the bidirectional memory 
mode. Block reads and writes can operate concurrently in bidirectional 
memory mode. If the bidirectional memory mode is disabled, only block 
reads can operate concurrently. 

The CMR instruction assures completion of all memory references within a 
particular CPU issuing the instruction. This instruction does not issue 
until all memory references before this instruction are at the stage of 
execution where completion occurs in a fixed amount of time. For 
example, a load of any data that has been stored by the CPU issuing 
instruction CMR is assured of receiving the updated data if the load is 
issued after the CMR instruction. Synchronization of memory references 
between processors can be done by this instruction in conjunction with 
semaphore instructions. 



Example: 



Code Generated 


Location| Result 


Operand 


Comment 




1 110 


20 


35 


002300 


|ERI 






002400 


|DRI 






002500 


|DBM 






002600 


|EBM 






002700 


|CMR 
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INSTRUCTIONS 0030, 0034, 0036, and 0037 









Machine | 


Result 


Operand 


Description 


Instruction | 


VM 


Sj 


Transmit (Sj) to VM 


0030J0 | 


VMt 





Clear VM 


003000 | 


SMjTctt 


1,TS 


Test and set semaphore jk, 
0<_jk<31 (decimal) 


0034J& | 


SMjfctt 





Clear semaphore jk, 0<^jk<31 
(decimal) 


0036J* | 


SMjfctt 


1 


Set semaphore jk, 0<_jk<31 
(decimal) 


0037jk | 



•f* Special CAL syntax 

ff This instruction is available when the numeric trait NUMCLSTR, which 

is specified on the CPU parameter of the CAL invocation statement, 

is greater than zero. 



Instruction 0030J0 and its special form transmit the contents of register 
Sj to the VM register. The VM register is zeroed if the j designator is 
0; the special form accommodates this case. 

This instruction may be used in conjunction with the vector merge 
instructions where an operation is performed depending on the contents of 
the VM register. 

Instruction 0034 jk tests and sets the semaphore designated by jk. If the 
semaphore is set, issue is held until another CPU clears that semaphore. 
If the semaphore is clear, the instruction issues and sets the semaphore. 

If all CPUs in a cluster are holding issue on a test and set, the DL flag 
is set in the Exchange Package (if it is not in monitor mode) and an 
exchange occurs. If an interrupt occurs while a test and set instruction 
is holding in the CIP register, the WS flag in the Exchange Package sets, 
CIP and NIP registers clear, and an exchange occurs with the P register 
pointing to the test and set instruction. 

The SM register is 3 2 bits with SM0 being the most significant bit. 

The 0036j7c instruction clears the semaphore designated by jk. 

Instruction 0037 jk sets the semaphore designated by jk. 
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INSTRUCTIONS 0030, 0034, 0036, and 0037 (continued) 



Example: 



Code Generated 


Location| Resu 


It 


Operand 


Comment 




1 1 10 


20 


35 


003040 


|VM 




S4 




003000 


|VM 







; Clear VM 


003407 


|SM7 




1,TS 




003607 


|SM7 









003707 


|SM7 




1 
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INSTRUCTION 0040 



| | | Machine 
Result | Operand | Description | Instruction 


EX | | Normal exit | 004000 



Instruction 004000 causes an exchange sequence. The contents of the 
instruction buffers are voided by the exchange sequence. If monitor mode 
is not in effect, the Normal Exit flag in the F register is set. All 
instructions issued before this instruction are run to completion. 

When the results of previously issued instructions have arrived at the 
operating registers, an exchange occurs to the Exchange Package 
designated by the contents of the Exchange Address (XA) register. The 
program address stored in the executing Exchange Package is advanced 1 
parcel from the address of the normal exit instruction. This instruction 
is used to issue a monitor request from a user program, or to transfer 
control from a monitor program to another program. 

The expression in the operand field is optional and has no effect on 
instruction execution; the low-order 9 bits of the expression value are 
placed in the ijk fields of the instruction. 



Example: 



| Code Generated 



Location! Result 



H= 



1004000 



10 



EX 



| Operand 
120 



| Comment 
125 
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INSTRUCTION 0050 



| | | Machine | 
Result | Operand | Description | Instruction | 


J | Bjk | Jump to (Bjk) | 0050J& | 



The 0050J& unconditional branch instruction sets the P register to the 
parcel address specified by the contents of register Bjk. Execution 
continues at that address. 



Example: 



Code Generated 



Location | Result 



Operand 



| Comment 



m 



20- 



.25_ 



1005017 

I 
1005003 



I 
U 



|B17 

I 
IB.RTNADDR 



RTNADDR=03 (octal) 
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INSTRUCTION 0060 



| | | Machine 
Result | Operand | Description | Instruction 


J | exp | Jump to exp | 006 ijkm 



The 006ijkm unconditional branch instruction sets the P register to the 
parcel address specified by the low-order 24 bits of the expression. 
Execution continues at that address. 



Example: 



|Code Generated 


Locationl Result 


| Operand 


Comment 


1 


1 110 


120 


35 


1 

|006 00002124b+ 

l 


I 

|J 
i 


1 

|TAG1 

1 




1 

|006 00001753a+ 


1 

u 


1 
|LDY3+1 
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INSTRUCTION 0070 



| | | Machine 
Result | Operand | Description | Instruction 


R | exp | Return jump to exp; set BOO to | 007 ijkm 
1 I (P) + 2. | 



Instruction OOlijkm sets register BOO to the address of the parcel 
following the instruction. The P register is then set to the parcel 
address specified by the low-order 24 bits of the expression. Execution 
continues at that address. 

The purpose of the instruction is to provide a return linkage for 
subroutine calls. The subroutine is entered via a return jump. The 
subroutine returns to the caller at the instruction following the call by 
executing a branch to the contents of the B register containing the saved 
address. 



Example: 



| Code Generated 


| Location| Result 


| Operand 


| Comment 


1 


|i |1Q 


120 


135 



I 

I 007 00001142d- 



|R 



HELP 
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INSTRUCTIONS 010 - 013 

















Machine 


Res 


3Ult 


Oper 


and 






Description 


Instruction 


JAZ 




exp 




Branch 


to 


exp if (A0)=0 


010 ijkm 


JAN 




exp 




Branch 


to 


exp if (A0)^0 


11 ij km 


JAP 




exp 




Branch 


to 


exp if (A0) positive 


12 ijkm 


JAM 




exp 




Branch 


to 


exp if (A0) negative 


013 ijkm 



NOTE 



When executing the above instructions on the CRAY X-MP 
computer systems, the high-order bit of i must be 0. 



The above instructions test the contents of A0 for the specified 
condition. If the condition is satisfied, the P register is set to the 
parcel address specified by the low-order 24 bits of the expression. 
Execution continues at that address. 

If the condition is not satisfied, execution continues with the 
instruction following the branch instruction. For the JAP and JAM 
instructions, a value in A0 is considered positive. 



Example: 



Code Generated 


Location| Result 


Operand 


Comment 




1 110 


20 


35 


010 00002243d+ 


| JAZ 


TAG3+2 




011 00004520a+ 


| JAN 


P.CON1 




012 00002221C+ 


| JAP 


TAG 2 




013 00002124b+ 


| JAM 


TAG1 
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INSTRUCTION 014 - 017 















Machine 


Result 


Oper 


and 






Description 


Instruction 


JSZ 


exp 




Branch 


to 


exp if (S0)=0 


14 ij&m 


JSN 


exp 




Branch 


to 


exp if (S0)^0 


015ijkm 


JSP 


exp 




Branch 


to 


exp if (SO) positive 


16 ij km 


JSM 


exp 




Branch 


to 


exp if (SO) negative 


onijkm 



NOTE 



When executing the above instructions on the CRAY X-MP 
computer system, the high-order bit of i must be 0. 



The above instructions test the contents of SO for the specified 
condition. If the condition is satisfied, the P register is set to the 
parcel address specified by the low-order 24 bits of the expression. 
Execution continues at that address. 

If the condition is not satisfied, execution continues with the 
instruction following the branch instruction. For the JSP and JSM 
instructions, a zero value in SO is considered positive. 



Example: 



Code Generated 


Location|Resu 


It 


I Operand 


Comment 




1 110 




120 


35 


014 00002221C+ 


| JSZ 




|TAG2 




015 00002124d+ 


| JSN 




ITAG1+2 




017 00002367c+ 


| JSM 




|TAG4 
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INSTRUCTION 01ft 



| | | Machine | 
Result | Operand | Description | Instruction | 


Aftt | exp | Transmit ijkm to Ah; where the | Olhijkm | 
| | high-order bit of i is 1 | | 



f This instruction is available through the logical trait EMA specified 
on the CPU parameter of the CAL invocation statement, and CAL will 
then generate one of these instructions: Olh, 020, 021, 022, or 031. 

Instruction 01ft will not be generated if NOEMA is specified. 



This instruction enters a 24-bit value into Aft that is composed of the 
low-order 24 bits of the ijkm field. The high-order bit of the ijkm 
field must be set to distinguish the 01ft instruction from the 010 to 
017 branches. 



Example: 



Code Generated 


Location 


Result 


| Operand 


Comment 




1 


10 


120 


35 






EXT 


| EXTSYM 




0a 0114 00000001+ 




Al 


| TABSYM 




c 0124 00000000X 




A2 


1 EXTSYM 




1 45 


TABSYM 


BSS 


|0'45 
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INSTRUCTIONS 020 - 022 



| | | Machine 
Result | Operand | Description | Instruction 


Ait | exp | Enter exp into Ai | 020 ij km or 
| | | 021ijkm or 
I | 1 022ijk 



f These instructions are available through the logical trait NOEMA 
specified on the CPU parameter of the CAL invocation statement/ and 
CAL will generate one of these instructions: 020, 021, 022, 031. 



The above instruction enters a quantity into Ai. The syntax differs 
from most CAL symbolic instructions in that the assembler generates any 
of three Cray machine instructions depending on the form, value, and 
attributes of the expression. 

The assembler generates an instruction 022ijk where the jk fields contain 
the 6-bit value of the expression if all of the following conditions are 
true: 

• The value of the expression is positive and less than 64 

• All symbols (if any) within the expression are previously defined 

• The expression has a relative attribute of absolute 

If any of the conditions are not true, the assembler generates either the 
2-parcel instruction 020ijkm or 021ijkm. If the expression has a 
positive value, or has a relative attribute of either relocatable or 
external, instruction 020ijkm is generated with the value entered in the 
22-bit jkm field. If the expression value is negative and has a relative 
attribute of absolute, instruction 021ijkm is generated with the ones 
complement of the expression value entered into the 22-bit jkm field 
except where the exp value is explicitly "-1". 
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INSTRUCTION 020 - 022 (continued) 



Example: 












| Code Generated 


Location 


Resu 


It 


Operand 


Comment 




1 


10 


20 


35 


1022310 




A3 




O'lO 




|0212 00000010 




A2 




#O'10 






AREG 


= 




2 




|0212 00000007 




A. AREG 


-O'lO 




|0202 00000130 




A2 




O'130 




|0203 00000021 




A3 




VAL+1 


; VAL=20 (octal) 


|0204 01777777 




A4 




q'1777777 




|0205 00051531 




A5 




A ' SY ' R 




|0226 00000000 




A6 
EXT 




| #MINUS1 


; MINUS1=-1 


|0204 17777777 




A4 




|X-1 


; 020 ijkm used if 
; expression is 
; external 
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INSTRUCTION 023 



Result 


Operand 


Description 


Machine 
Instruction 


Ai 
Ait 


SJ 

VL 


Transmit (Sj) to Ai 
Transmit (VL) to Ai 


02 3 i JO 
023i01 



f This instruction is available through the logical trait READVL 
specified on the CPU parameter of the CAL invocation statement, 



Instruction 023ij0 transmits the low-order 24 bits of the contents of 
register Sj to register Ai. Ai is zeroed if the j designator is 0. 

Instruction 023i01 enters the contents of the VL register into Ai. 



Example: 



| Code Generated | Location | Result | Operand | Comment 


1 11 110 120 135 


1 III 1 
1023420 | |A4 | S2 | 

1 III 1 
1 III 1 
1023201 | |A2 |VL | 
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INSTRUCTIONS 024 - 02 5 



Result 


Operand 


Description 


Machine 
Instruction 


Ai 
Bjk 


Bjk 
Ai 


Transmit (Bjk) to Ai 
Transmit (Ai) to Bjk 


024ij/c 
02 5ijfc 



Instruction Q24ijk enters the contents of register Bjk into register Ai. 
Instruction 025ij& enters the contents of register Ai into register Bjk. 



Example: 



Code Generated 


Location 


Result 


Operand 


Comment 




1 


10 


20 


35 


024517 




A5 


B17 






SVNTN 


= 


0'17 




024517 




A5 


B . SVNTN 




025634 




B34 


A6 




025634 




B.THRTY4 


A6 


; THRTY4=34 (o 
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INSTRUCTION 026 













Machine 


Resu 


It 


Oper 


and 


Description 


Instruction 


hi 




PSJ 




Population count of (Sj) to Ai 


026ij0 


Ait 




QSj 




Population count parity of (Sj) 
to Ai 


026ijl 


Aitt 




SBj 




Transfer (SBj) to Ai 


026IJ7 



f This instruction is available through the logical trait VPOP 

specified on the CPU parameter of the CAL invocation statement. 

ft This instruction is available when the numeric trait NUMCLSTR, which 
is specified on the CPU parameter of the CAL invocation statement, 
is greater than zero. 



Instruction 026ij0 counts the number of 1 bits in the contents of Sj 
and enters the result into Ai . Ai is zeroed if the j designator is 0. 

Instruction 026ijl enters a in Ai if Sj has an even number of 1 bits 
and enters a 1 in Ai if Sj has an odd number of 1 bits. 

These two instructions execute in the Scalar Leading Zero/Population 
Count functional unit. 

Instruction 026ij7 transfers the contents of the SBj register shared 
between the CPUs in the current cluster to Ai. 



Example: 



|Code Generated 


Location| Resu 


It 


Oper 


and 


Comment 




1 j 10 


20 


35 


1026720 


|A7 




PS2 




; Pop count of 
; S2 to A7 


1026271 


|A2 




QS7 




; Pop count 
; parity of 
; S7 to A2 


1026007 


|A0 




SB0 






1026017 


|A0 




|SB1 







HR-3005 



3-36 



INSTRUCTION 027 

























Machine 


Res 


ult 


Oper 


and 






De 


scription 








Instruction 


hi 




zsj 




Leadi 


ng 


zero 


count of 


(Sj) 


to 


hi 


027ij0 


SBjt 




hi 




Trans 


fer 


(hi) 


to SBj" 








027 ij7 



f This instruction is available when the numeric trait NUMCLSTR, which 
is specified on the CPU parameter of the CAL invocation statement, is 
greater than zero. 



Instruction 027 ij'O counts the number of leading zeros in the contents of 
Sj and enters the result into hi. hi is set to 64 if the j designator 
is 0, or if the Sj register contains 0. 

This instruction executes in the Scalar Leading Zero/Population Count 
functional unit. 

Instruction 027ij7 transfers the contents of register hi into register 
SBj, which is shared between the CPUs in the current cluster. 



Example: 



Code Generated 


Location|Resu 


It 


| Operand 


Comment 




1 110 




120 


35 


027130 


|A1 




|ZS3 




027007 


|SB0 




|A0 




027107 


|SB0 




|A1 
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INSTRUCTIONS 030 - 031 









Machine 


Result 


Operand 


Description 


Instruction 


hi 


kj+kk 


Integer sum of (Aj) and (kk) 
to Ai 


030ijfc 


Ait 


Aj + l 


Integer sum of (Aj) and 1 to Ai 


030ij0 


Ait 


A* 


Transmit (kk) to Ai 


030i0* 


Ai 


kj-kk 


Integer difference of (Aj) less 
(kk) to Ai 


031ij* 


Ait 


kj-1 


Integer difference of (Aj) less 
1 to Ai 


031ij0 


Ait 


-kk 


Transmit negative of (kk) to Ai 


031i0* 


Ait 


-1 


Enter -1 into Ai 


031i00 



f Special CAL syntax 



Instruction 030 ijk and its special form (030ij0) add the contents of 
register kj to the contents of register kk and enter the result into 
register Ai. kk is transmitted to Ai when the j designator is and the 
k designator is nonzero. The value 1 is transmitted to Ai when the j and 
k designators are both 0. (Aj)+1 is transmitted to Ai when the j 
designator is nonzero and the k designator is 0. The assembler allows an 
alternate form of the instruction when the k designator is 0. 

The instruction executes in the Address Integer Add functional unit. 

Instruction 030i0fc enters the contents of register kk into register Ai. 
The value 1 is entered if the k designator is 0. 
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INSTRUCTIONS 030 - 031 (continued) 



Instruction 031ij& and its special form (031ij0) subtract the contents of 
register Ak from the contents of register Aj and enter the result into 
register Ai. The negative of kk is transmitted to Ai when the j 
designator is and the k designator is nonzero. A -1 is transmitted to 
Ai when the j and k designators are both 0. (Aj)-l is transmitted to Ai 
when the j designator is nonzero and the k designator is 0. 

The instruction 031ijk executes in the Address Integer Add functional 
unit. 

The special form represents the case where (kk)=l if &=0. 

Instruction 031i0fc enters the negative (twos complement) of the contents 
of register kk into register Ai. The value -1 is entered into Ai if the 
k designator is 0. 

Instruction 031i00 is generated in place of instruction 020ijkm if the 
operand is explicitly -1. 



Example: 



Code Generated 


Location | Res 


ult 


Operand 


Comment 




1 110 


120 


35 


030123 


|A1 




A2+A3 




030102 


|A1 




A2 




030230 


|A2 




A3 + 1 




030602 


|A6 




A2 




031456 


|A4 




A5-A6 




031102 


|A1 




-A2 




031450 


|A4 




A5-A1 




031703 


|A7 




-A3 




031300 


| A3 




-1 
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INSTRUCTION 032 



| | | Machine 
Result | Operand | Description | Instruction 


Ai | Aj*kk | Integer product of (Aj) and | 032ijk 
| | (A*) to Ai | 



Instruction 032ijk forms the integer product of the contents of register 
Aj and register Ak and enters the low-order 24 bits of the result into 
Ai. Ai is cleared when the j designator is 0. Aj is transmitted to Ai 
when the k designator is and the j designator is nonzero. 

The instruction executes in the Address Integer Multiply functional 
unit. There is no overflow detection. 



Example: 



| Code Generated 



| Location | Result 
II HO 



| Operand 
120 



Comment 
35 



1032712 



A7 



|A1*A2 
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INSTRUCTION 033 













Machine | 


Result 


Operand 


Description 






Instruction | 


Ai 


CI 


Channel number of highest 






033i00 | 






priority interrupt request 


to 


Ai 




hi 


Ch,hj 


Address of channel (Aj) to 
(J*0) 


Ai 




033ij0 | 


hi 


CE , hj 


Error flag of channel (Aj) 


to 


Ai 


033ijl | 



Instruction 033i00 enters the channel number of the highest priority 
interrupt request into Ai . 

Instruction 033ij0 enters the contents of the Current Address (CA) 
register for the channel specified by the contents of Aj into register 
Ai. 

Instruction 033ijl enters the error flag for the channel specified by 
the contents of Aj into the low-order 7 bits of Ai. The high-order 
bits of Ai are cleared. The error flag can be cleared only in monitor 
mode using the CI,Aj instruction, or the CRAY X-MP computer system 
instruction MC,Aj. 



Example: 



Code Generated 


Location | Resu 


It 


| Operand 


Comment 




1 110 




120 


35 


033100 


|A1 




|CI 




033230 


|A2 




|CA,A3 




033341 


| A3 




|CE,A4 
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INSTRUCTIONS 034 



037 











Machine | 


| Result 


Oper 


and 


Description 


Instruction | 


1 1 
| Bjk,hi 


,A0 




Read (hi) words starting at 

Bjk from memory starting at (A0) 


034ijfc | 


| Bjfc,Ait 


0,A0 




Read (hi) words starting at 

Bjk from memory starting at (A0) 


034ij& | 


I ,A0 


Bjk, 


hi 


Store (hi) words starting at 
Bjk to memory starting at (A0) 


035ij* | 


| 0,A0t 


Bjk, 


hi 


Store (hi) words starting at 
Bjk to memory starting at (A0) 


035ij* | 


1 Tjk,hi 


,A0 




Read (hi) words starting at 

Hjk from memory starting at (A0) 


036ij* | 


| Tj/cAit 


O,A0 




Read (hi) words starting at 

Tjk from memory starting at (A0) 


036ij* | 


I ,A0 


Tjk, 


hi 


Store (hi) words starting at 
Tjk to memory starting at (A0) 


031ijk | 


| 0,A0t 


ijk. 


hi 


Store (hi) words starting at 
Tjk to memory starting at (A0) 


037ij* | 



f Special CAL syntax 



Instruction 034ij& and its special form are used to transfer words from 
memory directly into B registers. A0 contains the address of the first 
word of memory to be transferred. The jk designator specifies the first 
B register to be used in the transfer. The low-order 24 bits of 
consecutive words of memory are loaded into consecutive B registers. 

Processing of B registers is circular. BOO is loaded after B77 if the 
count specified in hi is not exhausted after B77 is loaded. The 
low-order 7 bits of the contents of hi specify the number of words 
transmitted. Wraparound occurs if the low-order 7-bits of (hi) are 
greater than 64. 

If (Ai)=0, no words are transferred. Note also that if i=0, (A0) is used 
for the block length as well as the starting memory address. The CAL 
assembler issues a warning message in this case. 
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INSTRUCTIONS 034 - 037 (continued) 



Instruction 035ij'7c and its special form are used to store words from B 
registers directly into memory. A0 contains the address of the first 
word of memory to receive data. The jk designator specifies the first 
B register to be used in the transfer. Subsequent B register contents 
are stored in consecutive words of memory. 

Processing of B registers is circular. BOO is processed after B77 if the 
count specified in hi is not exhausted after B77 is processed. The 
low-order 7 bits of the contents of hi specify the number of words 
transmitted. Wraparound occurs if the low-order 7-bits of hi are greater 
than 64 . 

If (Ai)=0, no words are transferred. Note also that if i=Q , (A0) is used 
for the block length as well as the starting memory address. The CAL 
assembler issues a warning message in this case. 

Instruction 036ijk and its special form are used to transfer words from 
memory directly into T registers. A0 contains the address of the first 
word of memory to be transferred. The jk designator specifies the first 
T register to be used in the transfer. The loading of T registers is 
circular. TOO is loaded after T77 if the count specified in hi is not 
exhausted after T77 is loaded. The low-order 7 bits of the contents of 
hi specify the number of words transmitted. Wraparound occurs if the 
low-order 7-bits of hi are greater than 64. 

If (Ai)=0, no words are transferred. If i=0, (A0) is used for the block 
length and the starting memory address. The CAL assembler issues a 
warning message in this case. 

Instruction 037ijk and its special form are used to store words from T 
registers directly into memory. A0 contains the address of the first 
word of memory to receive data. The jk designator specifies the first 
T register to be used in the transfer. Subsequent T register contents 
are stored in consecutive words of memory. Processing of T registers is 
circular. TOO is processed after T77 if the count specified in hi is 
not exhausted after T77 is processed. The low-order 7 bits of the 
contents of register hi specify the number of words transmitted. 
Wraparound occurs if the low-order 7-bits of hi are greater than 64. 

If (Ai)=0/ no words are transferred. Note also that if i=0, (A0) is used 
for the block length as well as the starting memory address, and CAL 
issues a warning message. 
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Example: 



INSTRUCTIONS 034 - 037 (continued) 



Code Generated 


Location 


Result 




Operand 


Comment 




1 


10 


20 


35 


034407 




B7,A4 




,A0 




034522 


BB 
FWAR 


B.BB,A. 


FWAR 


0'22 

5 

0,A0 




035522 




,A0 




B22,A5 




035522 


BB 
FWAR 


0,A0 




0'22 

5 

B.BB,A.FWAR 




036407 




T7,A4 




,A0 




036522 


TT 
FWAR 


t.tt,a 


FWAR 


0'22 

5 

0,A0 




37522 




,A0 




T22,A5 




037522 


TT 
FWAR 


0,A0 




0'22 

5 

T.TT,A.FWAR 
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INSTRUCTIONS 040 - 041 



| | | Machine 
Result | Operand | Description | Instruction 


Si | exp | Enter exp into Si | OAOijkm or 
| | | 041ijfcm 



The above instruction enters a quantity into Si. Either the 2-parcel 
Q40ijkm instruction or the 2-parcel OAlijkm instruction is generated, 
depending on the value of the expression. 

If the expression has a positive value or a relative attribute of either 
relocatable or external, instruction 040ijfon is generated with the 
22-bit jkm field containing the expression value. If the expression 
has a negative value and a relative attribute of absolute, instruction 
041ij&m is generated with the 22-bit jkm field containing the ones 
complement of the expression value. 

Refer to the 042-043 instructions for additional information on Si exp 
instructions. 

Example: 



Code Generated 


Location 


Result 


Operand 


Comment 




1 


10 


20 


35 


0402 00000130 




S2 


O'130 




0403 00000021 


SREG 


S.SREG 


3 
VAL+1 


; VAL=20 (octal 


0404 01777777 




S4 


0'1777777 




0405 00051531 




S5 


A ' SY ' R 

3 

#MINUS1 




0406 00000000 




S6 


; MINUS 1=-1 


0413 00000002 




S3 


#2 




0414 01777776 




S4 


-0' 1777777 




0414 00000003 




S4 


#VAL2 


; VAL2=3 


0401 17777777 




EXT 
SI 


X 
X-l 


; 040 i jkm used 
; if expression 
; is external 
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INSTRUCTIONS 042 - 043 













Machine 


Re 


suit 


Operand 


Description 




Instruction 


Si 




<exp 


Form ones mask in Si from 
right 




04 2 ij* 


Sit 




#>exp 


Form zeros mask in Si from 
left 




04 2 ij* 


Sit 




1 


Enter 1 into Si 




042i77 


Sit 




-1 


Enter -1 into Si 




042i00 


Sit 







Clear Si 




043i00 


Si 




>exp 


Form ones mask in Si from ] 


.eft 


04 3 ijk 


Sit 




#<exp 


Form zeros mask in Si from 


right 


04 3 ijk 



f Special CAL syntax 



Instruction 042ij& generates a mask of ones from the right. The 
assembler evaluates the expression to determine the mask length. 

In the first instruction, the mask length is the value of the 
expression. In the second instruction, the mask length is 64 minus the 
expression value. The mask length must be a positive integer not 
exceeding 64; 64 minus the mask length is inserted into the jk fields of 
the instruction. If the value of the expression is for the first 
instruction or 64 for the second instruction, the assembler generates 
instruction 043i00. 

Instruction 0A2ijk executes in the Scalar Logical functional unit. 

Instructions 042i77, 042i00, and 043i00 are initially recognized by the 
assembler as the symbolic instruction Si exp. The assembler then checks 
the expression to see if it has one of these three forms. If it finds 
one of the forms in the exact syntax shown, it generates the 
corresponding Cray machine instruction. If none of these forms is found, 
instruction 040ijkm or 041ijkm is generated. These special forms allow 
more efficient instructions for entering often used values into SI. 

Instructions 043i00, 042i77, and 042i00 execute in the Scalar Logical 
functional unit. 
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INSTRUCTIONS 042 - 043 (continued) 



Instruction 043ij& generates a mask of ones from the left. The assembler 
evaluates the expression to determine the mask length. 

In instruction 043ij&, the mask length is the value of the expression. 
In the special syntax form, the mask length is 64 minus the expression 
value. The mask length must be a positive integer not exceeding 64 and 
is inserted into the jk fields of the instruction. If the expression 
value is 64 for the first instruction or for the second instruction, 
the assembler generates instruction 042i00. 

Instruction 043ij& executes in the Scalar Logical functional unit. 



Example: 



Code Generated 


Location |Resu 


It 


| Operand 


Comment 




1 110 




120 


35 


042200 


|S2 




1-1 




042273 


|S2 




|<5 




042273 


|S2 




|#>0'73 




042366 


| S3 




| <D'10 




042400 


|S4 




|<O'100 




043500 


|S5 




|<0 




043600 


|S6 




|0 


; Clear S6 


042677 


|S6 




|1 


; Set S6 to 1 


043205 


|S2 




1 >5 




043205 


|S2 




|#<0'73 




043500 


|S5 




1 <o 
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INSTRUCTIONS 044 - 051 









Machine | 


Result 


Operand 


Description 


Instruction | 


Si 


Sj&Sk 


Logical product of (Sj) and (Sk) 
to Si 


044ij/c | 


Sit 


Sj&SB 


Sign bit of (Sj) to Si 


044ij0 | 


Sit 


SB&Sj 


Sign bit of (Sj) to Si; j*0 


044ij0 | 


Si 


#S*&SJ 


Logical product of (Sj) and 
#(S*) to Si 


045ijfc | 


Sit 


#SB&Sj 


(Sj) with sign bit cleared to Si 


045ij0 | 


Si 


Sj\Sk 


Logical difference of (Sj) and 
(Sk) to Si 


046ij7c | 


Sit 


Sj\SB 


Enter (Sj) into Si with sign bit 
toggled 


046ij0 | 


sit 


SB\Sj 


Enter (Sj) into Si with sign bit 
toggled; jtQ 


046ij0 | 


Si 


#sj\s& 


Logical equivalence of (Sj) and 
(Sk) to Si 


OAlijk | 


Sit 


#Sj\SB 


Logical equivalence of (Sj) and 
sign bit to Si 


047ij0 | 


sit 


#SB\Sj 


Logical equivalence of sign bit 
and (Sj) to Si; j*0 


047ij0 | 



f Special CAL syntax 



NOTE 



When the above instructions execute, SB with no 
register designator is the sign bit, not Shared B 
register. 
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INSTRUCTIONS 044 - 051 (continued) 









Machine | 


| Result 


Operand 


Description 


Instruction | 


! sit 


#S& 


Transmit ones complement of 
(Sk) to Si 


047i0& | 


! sit 


#SB 


Enter ones complement of sign 
bit in Si 


047i00 | 


1 Si 


Sj!Si&Sfc 


Scalar merge of (Si) and (Sj) 
to Si 


50 ijk | 


! Sit 


Sj!Si&SB 


Scalar merge of (Si) and sign 
bit of (Sj) to Si 


050ij0 | 


1 Si 


S j ! Sk 


Logical sum of (Sj) and (Sk) 
to Si 


051ijfc | 


! sit 


Sj ! SB 


Logical sum of (Sj) and sign 
bit to Si 


051ij0 1 


j sit 


SB ! S j 


Logical sum of sign bit and (Sj) 
to Si; j*0 


051ij0 | 


I Sit 


Sk 


Transmit (Sk) to Si 


051i0/c | 


! sit 


SB 


Enter sign bit into Si 


051i00 | 



f Special CAL syntax 



NOTE 



When the above instructions execute, SB with no 
register designator is the sign bit, not Shared B 
register. 



Instruction 044ij& forms the logical product of the contents of Sj and 
ST: and enters the result into Si. If the j and k designators have the 
same nonzero value, the contents of Sj is transmitted to Si. 
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INSTRUCTIONS 044 - 051 (continued) 



If the j designator is 0/ register Si is zeroed. If the j designator is 
nonzero and the k designator is 0, the sign bit of the contents of Sj is 
extracted. The two special forms of the instruction accommodate this 
case. The two forms perform identical functions/ but j must not be equal 
to in the second form. If j is equal to 0, an assembly error results. 

Instruction 045ij& forms the logical product of the contents of Sj and 
the ones complement of the contents of Sk and enters the result into Si. 
If the j and k designators have the same value or if the j designator is 
0, register Si is zeroed. 

If the j designator is nonzero and the k designator is 0/ the contents of 
Sj with the sign bit cleared is transmitted to Si. The special syntax 
form accommodates this case. 

Instruction 046ijk forms the logical difference of the contents of Sj and 
the contents of Sk and enters the result into Si. If the j and k 
designators have the same nonzero value, Si is zeroed. 

If the j designator is and the k designator is nonzero, the contents of 
Sk is transmitted to Si. If the j designator is nonzero and the k 
designator is 0, the sign bit of the contents of Sj is complemented and 
the result is transmitted to Si. The two special syntax forms provide 
for this case. The two forms perform identical functions; however, in 
the second form, j must not equal 0. If j equals 0, an assembly error 
results. 

Instruction 047 ijk forms the logical equivalence of the contents of Sj 
and the contents of Sk and enters the result into Si. Bits of Si are 
set to 1 when the corresponding bits of the contents of Sj and the 
contents of Sk are both 1 or both 0. 

If the j and k designators have the same nonzero value, the contents of 
Si is set to all ones. If the j designator is and the k designator is 
nonzero, the ones complement of the contents of Sk is transmitted to Si. 
If the j designator is nonzero and the k designator is 0, all bits other 
than the sign bit of the contents of Sj are complemented and the result 
is transmitted to Si. 

The two special forms of the instruction accommodate this case. The two 
forms perform identical functions; however, in the second form, j must 
not equal 0. If j equals 0, an error results. 
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INSTRUCTIONS 044 - 051 (continued) 



Instruction 047i0& forms the ones complement of the contents of register 
Sk and enters the value into Si. The complement of the sign bit is 
entered into Si if the k designator is 0. 

Instruction 047i00 clears the sign bit and sets all other bits. 

Instructions 050ijk and 050ij0 merge the contents of Sj with the contents 
of Si depending on the ones mask in Sk. 

The result is defined by (Sj&S/c) ! (Si&#S&) as in the following example: 

(Sk) = 11110000 

(Si) = 11001100 

(Sj) = 10101010 

(Si) = 10101100 

This instruction is intended for merging portions of 64-bit words into a 
composite word. Si bits are cleared when the corresponding Sk bits are 
1 if the j designator is and the k designator is nonzero. The sign 
bit of Sj replaces the sign bit of Si if the j designator is nonzero and 
the k designator is as provided for by the special syntax form of the 
instruction. The sign bit of Si is cleared if the j and k designators 
are both 0. 

Instruction 051ijk forms the logical sum of the contents of Sj and the 
contents of Sk and enters the result into Si. If the j and k designators 
have the same nonzero value, the contents of Sj are transmitted to Si. 
If the j designator is and the k designator is nonzero, the contents of 
Sk are transmitted to Si. 

If the j designator is nonzero and the 7c designator is 0, the contents 
of Sj with the sign bit set to 1 are transmitted to Si. The two special, 
syntax forms provide for this case. If the j and k designators are both 
0, a ones mask consisting of only the sign bit is entered into Si. 

The two special forms perform an identical function but in the second 
form jj*0; if j=0, an assembly error results. 

Instruction 051i0k enters the contents of register Sk into register Si. 
The sign bit is set to 1 in Si if the k designator is 0. 

Instruction 051i00 can be used to set the sign bit of Si and zero all 
other bits. 

Instructions 044ij7c through 051 execute in the Scalar Logical functional 
unit. 
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INSTRUCTIONS 044 - 051 (continued) 



Example: 



Code Generated 



Location 



Result 



Operand 



Comment 



10 



20 



25_ 



044235 
044655 
044160 
044160 
045271 
045430 

045506 
045670 
046123 
046455 
046506 
046770 

047345 
047260 
047260 
047203 
047200 
050123 
050760 



S2 
S6 
SI 
SI 
S2 
S4 

S5 
S6 
SI 
S4 
S5 
S7 

S3 
S2 
S2 
S2 
S2 
SI 
S7 



S3&S5 

S5&S5 

S6&SB 

SB&S6 

#S1&S7 

#SB&S3 

#S6&S0 

#SB&S7 

S2\S3 

S5\S5 

S0\S6 

S7\SB 

#S4\S5 

#S6\SB 

#SB\S6 

#S3 

#SB 

S2IS1&S3 

S6!S7&S0 



; S5 to S6 

; Get sign of S6 

; Get sign of S6 

; Clear sign bit 

; of S3 and 

; enter into S4 

; Clear S5 

; Clear sign bit 

; Clear S4 

; S6 to S5 

; Toggle sign 

; bit 
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INSTRUCTIONS 044 - 051 (continued) 



Example (continued) 



Code Generated 


Locat 


ion 


Result 


Operand 


Comment 




1 


10 


20 


35 


051472 






S4 


S7!S2 




051366 






S3 


S6!S6 




051710 






S7 


SB!S1 




051701 






S7 


SI 






I 




= 


1 




051100 






S.I 


SB 
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INSTRUCTIONS 052 - 055 













Machine 


Result 


Operand 






Description 


Instruction 


SO 


Si<exp 


Shift 
to SO 


(Si) 


left exp places 


52 ij A: 


SO 


Si>exp 


Shift 
to SO 


(Si) 


right exp places 


53 ijk 


Si 


Si<exp 


Shift 
to Si 


(Si) 


left exp places 


054ij& 


Si 


Si>exp 


Shift 
to Si 


(Si) 


right exp places 


055ijfc 



Instruction 052ijk shifts the contents of Si to the left by the amount 
specified by the expression and enters the result into SO. The shift 
count must be a positive integer value not exceeding 64. The shift is 
end off with zero fill. If the shift count is 64, instruction 053000 is 
generated and SO is zeroed. 

Instruction 053ijk shifts the contents of Si to the right by the amount 
specified by the expression and enters the result into SO. The shift 
count must be a positive integer value not exceeding 64. The assembler 
stores 64 minus the shift count in the jk field of the instruction. 
The shift is end off with zero fill. If the shift count is 0, 
instruction 052i00 is generated and the content of SO is not altered. 

Instruction Q54ijk shifts the contents of Si to the left by the amount 
specified by the expression and enters the result into Si. The shift 
count must be a positive integer value not exceeding 64. The shift is 
end off with zero fill. If the shift count is 64, instruction 055i00 
is generated and Si is zeroed. 

Instruction 055ijk shifts the contents of Si to the right by the amount 
specified by the expression and enters the result into Si. The shift 
count must be a positive integer value not exceeding 64. The assembler 
stores 64 minus the shift count in the jk field of the instruction. If 
the shift count is 0, instruction 054i00 is generated and the content 
of Si is not altered. The shift is end off with zero fill. 

Instructions 052ijk, 053ijx, 054ijA: / and 055ijk execute in the Scalar 
Shift functional unit. 
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Example: 



INSTRUCTIONS 052 - 055 (continued) 



Code Generated 


Location | Result 


Operand 


Comment 




1 110 


20 


35 


052305 


|S0 


S3<5 




052724 


|S0 


S7<VAL+4 




053373 


|S0 


S3>5 




053066 


|S0 


S0>D'10 




053754 


|S0 


S7>VAL+4 




052100 


|S0 


S1>0 




054703 


|S7 


S7<3 




054622 


|S6 


S6<VAL+2 




055775 


|S7 


S7>3 




055656 


|S6 


S6>VAL+2 
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INSTRUCTIONS 056 - 057 









Machine 


Result 


Operand 


Description 


Instruction 


Si 


Si,Sj<A/c 


Left shift by (kk) of (Si) and 
(Sj) to Si 


056ijfc 


Sit 


Si,Sj<l 


Left shift by 1 of (Si) and (Sj) 
to Si 


056ij0 


Sit 


Si<Afc 


Left shift by (A*) of (Si) to Si 


056i0k 


Si 


Sj,Si>kk 


Right shift by (kk) of (Sj) and 
(Si) to Si 


057ij& 


Sit 


Sj,Si>l 


Right shift by 1 of (Sj) and 
(Si) to Si 


057ij0 


Sit 


Si>kk 


Right shift by (A*) of (Si) 
to Si 


057i0k 



f Special CAL syntax 



Instruction 056ijk and its special forms produce a 128-bit quantity by 
concatenating the contents of Si and the contents of Sj, shifting the 
resulting value to the left by an amount specified by the low-order bits 
of kk and entering the high-order bits of the result into Si. The shift 
is end off with zero fill. 

Replacing the kk reference with 1 is the same as setting the k designator 
to 0; a reference to A0 provides a shift count of 1. Omitting the Sj 
reference is the same as setting the j designator to 0; the contents of 
Si are concatenated with a word of zeros. 

Si is cleared if the shift count exceeds 127. The shift is a left 
circular shift of the contents of Si if the shift count does not exceed 
64 and the i and j designators are equal and nonzero. The instruction 
produces the same result as the Si Si<exp instruction if the shift count 
does not exceed 63 and the k designator is 0. The contents of Sj are 
not affected if the i and j designators are unequal. 

Instruction Q57ijk and its special forms produce a 128-bit quantity by 
concatenating the contents of Sj and the contents of Si, shifting the 
resulting value to the right by an amount specified by the low-order 7 
bits of the contents of kk and entering the low-order bits of the 
result into Si. The shift is end off with zero fill. 
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INSTRUCTIONS 056 - 057 (continued) 



Replacing the kk reference with 1 is the same as setting the k designator 
to 0; a reference to A0 provides a shift count of 1. Omitting the Sj 
reference is the same as setting the j designator to 0; the contents of 
Si are concatenated with a word of zeros. 

Si is cleared if the shift count exceeds 127. The shift is a right 
circular shift of the contents of Si if the shift count does not exceed 
64 and the i and j designators are equal and nonzero. The instruction 
produces the same result as the Si Si>exp instruction if the shift 
count does not exceed 63 and the j designator is 0. The contents of Sj 
are not affected if the i and j designators are unequal. 



Instruction 056ijk and 051 ijk executes in the Scalar Shift functional 
unit. 



Example: 



Code Generated 


Location | Rest 


alt 


Operand 


Comment 




1 110 


20 


35 


056235 


|S2 




S2,S3<A5 




056340 


| S3 




S3,S4<1 


; Left 1 place 


056604 


|S6 




S6<A4 




057235 


|S2 




S3,S2>A5 




057604 


|S6 




S6>A4 




057340 


| S3 




S4,S3>1 


; Right 1 place 
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INSTRUCTIONS 060 - 061 









Machine 


Result 


Operand 


Description 


Instruction 


Si 


Sj+Sk 


Integer sum of (Sj) and (Sk) 
to Si 


060ij& 


Si 


Sj-Sk 


Integer difference of (Sj) less 
(Sk) to Si 


061ijfc 


Sit 


-Sk 


Transmit negative of (Sk) to Si 


061i0& 



f Special CAL syntax 



Instruction 060ij& adds the contents of register Sk to the contents of 
register Sj and enters the result into Si. Sk is transmitted to Si if 
the j designator is and the k designator is nonzero. The sign bit is 
entered in Si and all other bits of Si are cleared if the j and k 
designators are both 0. 

Instruction 061ij& subtracts the contents of register Sk from the 
contents of register Sj and enters the result into Si. The high-order 
bit of Si is set and all other bits of Si are cleared when the j and k 
designators are both 0. The negative (twos complement) of Sk is 
transmitted to Si if the j designator is and the k designator is 
nonzero. 

Instruction 061i0k enters the negative (twos complement) of the contents 
of Sk into Si. The sign bit is set if the k designator is 0. 

Instructions 060ijfc, 061ijfc, 061i0fc execute in the Scalar Integer Add 
functional unit. 



Example: 



Code Generated 


Location] Resi 


ult 


Operand 


Comment 




1 110 


20 


35 


060237 


|S2 




S3+S7 




060405 


|S4 




S0+S5 




061123 


| SI 




S2-S3 




061506 


|S5 




-S6 
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INSTRUCTIONS 062 - 063 









Machine | 


| Result 


Operand 


Description 


Instruction | 


1 Si 


Sj+FSk 


Floating-point sum of (Sj) and 
(Sk) to Si 


062ijk | 


| Sit 


+FSk 


Normalize (Sk) to Si 


062i0fc | 


1 Si 


Sj-FSTc 


Floating-point difference of 
(Sj) less (Sk) to Si 


06 3 ij& | 


! Sit 


-FSk 


Transmit the negative of (Sk) 
as a normalized floating-point 
value 


063i0k | 



f Special CAL syntax 



Instruction 062ijk and its special form produce the floating-point sum 
of the contents of the Sj and Sk registers and enters the result into 
Si. The result is normalized even if the operands are unnormalized. 
The k designator is not normally 0. In the special form, the j 
designator is assumed to be so that the normalized contents of Sk are 
entered into Si. 

Instruction 063ij& forms the floating-point difference of the contents 
of register Sj less the contents of register Sk, and enters the 
normalized result into Si. The result is normalized even if the 
operands are unnormalized. 

The negative (twos complement) of the floating-point quantity in Sk is 
transmitted to Si as a normalized floating-point number if the j 
designator is and the 7c designator is nonzero. The special form 
accommodates this special case. The k designator is normally nonzero. 

Instructions 062ijk, 063ijk, and 063i0k execute in the Floating-point 
Add functional unit. 
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INSTRUCTIONS 062 - 063 (continued) 



Example: 



Code Generated 


Location| Resu 


It 


Operand 


Comment 




1 1 10 


20 


35 


062345 


| S3 




S4+FS5 




062404 


|S4 




+FS4 




063302 


| S3 




-FS2 




063761 


|S7 




S6-FS1 
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INSTRUCTIONS 064 - 067 









Machine 


Result 


Operand 


Description 


Instruction 


Si 


Sj*FS& 


Floating-point product of (Sj) 
and (Sk) to Si 


64 ijfc 


Si 


Sj*ESk 


Half-precision rounded 
floating-point product of (Sj) 
and (Sk) to Si 


065ij& 


Si 


Sj*RSk 


Rounded floating-point product 
of (Sj) and (Sk) to Si 


066ij& 


Si 


Sj*ISk 


2-f loating-point product of (Sj) 
and (Sk) to Si 


067 ijk 



Instruction 064ijfc forms the floating-point product of the contents of 
Sj and Sk and enters the result into Si. The result is not normalized 
if either operand is unnormalized. 

Instruction 065ij& forms the half-precision rounded floating-point 
product of the contents of the Sj and Sk registers and enters the 
result into Si. The result is not normalized if either operand is 
unnormalized. The low-order 18 bits of the result are zeroed. This 
instruction can be used in a divide algorithm when only 30 bits of 
accuracy are required. 

Instruction Q66ijk forms the rounded floating-point product of the 
contents of the Sj and Sk registers and enters the result into Si. The 
result is not normalized if either operand is unnormalized. This 
operation is used in the reciprocal approximation sequence. 

Instruction 067 ijk forms 2 minus the floating-point product of the 
contents of Sj and Sk and enters the result into Si. The result is not 
normalized if either operand is unnormalized. 

Instructions 064ij7c, 065ijk, 066ijk, and 067 ijk execute in the 
Floating-point Multiply functional unit. 
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INSTRUCTIONS 064 - 067 (continued) 



Example: 



Code Generated 


Location | Resu 


Lit 


Operand 


Comment 




1 110 


20 


35 


064234 


|S2 




S3*FS4 




065167 


| SI 




S6*HS7 




066147 


| SI 




S4*RS7 




067324 


| S3 




S2*IS4 
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INSTRUCTION 070 



| | | Machine 
Result | Operand | Description | Instruction 


Si | /HSj | Floating-point reciprocal | 070ij0 
| | approximation of (Sj) to Si | 



Instruction 070ij0 forms an approximation to the reciprocal of the 
floating-point value in Sj and enters the result into Si. The result is 
meaningless if the contents of Sj is unnormalized or 0. This instruction 
is used in the divide seguence as illustrated in the following example. 

Instruction 070ij0 executes in the Floating-point Reciprocal functional 
unit. 



Example: 



Code Generated 


Location 


Res 


;ult 




I Operand 






| Comment 




1 


10 






120 






135 


070320 


* 


Divide 
S3 


SI 


1 
by S2; resi 
|/HS2 

1 
I 


alt 


to J 


51 
; Approximate 
| ; reciprocal 


064113 




SI 






1 
|S1*FS3 

1 
i 






; Approximate 
; result 


067223 




S2 






1 
|S2*IS3 

1 
i 






; Correction 
; factor 


064112 




SI 






1 
|S1*FS2 

1 








070320 


* 
* 


Divide 
30 bits 
S3 


SI 


1 
by S2 with 

1 

|/HS2 

1 


result 


accurate to 


065313 




S3 






1 
|S1*HS3 
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INSTRUCTION 070 (continued) 



Example (continued) 



Code Generated 


Location| Result 


| Operand 


| Comment 




1 110 


120 


| 35 


071222 


* | Integer 
|S2 


divide Al by A2; 
I+FA2 


Resu 
1 / 


Lt to A3 
Denominator 


071121 


j SI 


l+FAl 


1 / 


Numerator 


062202 


|S2 


IS0+FS2 


1 s 


Normalize 


062101 


|S1 


IS0+FS1 






070220 


|S2 


|/HS2 


1 / 
1 / 
1 s 


Reciprocal 
approximation 
to 1/D 


065110 


| SI 


|S1*HS2 


1 / 
1 / 
1 / 


Rounded 

half-precisio 

multiply 


071230 


|S2 


|0.6 






062112 


| SI 


IS1+FS2 


1 / 


Fix quotient 


023310 


|A3 


| SI 


1 / 
1 / 


24-bit signed 
result to A3 
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INSTRUCTION 071 









Machine | 


Result 


Operand 


Description 


Instruction | 


Si 


Ak 


Transmit (Ak) to Si without sign 
extension 


OlliOk | 


Si 


+Ak 


Transmit (Ak) to Si with sign 
extension 


071ilfc | 


Si 


+FAk 


Transmit (Ak) to Si as an 
unnormalized floating-point 
value 


071i27c | 


Si 


0.6 


Enter 0.75*(2**48) into Si as 
normalized floating-point 
constant 


071i30 | 


Si 


0.4 


Enter 0.5 into Si as normalized 
floating-point constant 


071i40 | 


Si 


1. 


Enter 1 into Si as normalized 
floating-point constant 


071i50 | 


Si 


2. 


Enter 2 into Si as normalized 
floating-point constant 


071i60 | 


Si 


4. 


Enter 4 into Si as normalized 
floating-point constant 


071i70 | 



Instruction 071i07c transfers the 24-bit value in register Ak into the 
low-order 24 bits of register Si. The value is treated as an unsigned 
integer. The high-order bits of Si are zeroed. A value of 1 is entered 
into Si when the k designator is 0. 

Instruction 071il7c transfers the 24-bit value in register Ak into the 
low-order 24 bits of register Si. The value is treated as a signed 
integer and the sign bit of the contents of register Ak is extended to 
the high-order bits of Si. A value of 1 is entered into Si when the k 
designator is 0. 

Instruction 071i2k transmits the contents of register Ak to Si as an 
unnormalized floating-point value. The result can then be added to to 
normalize. When the k designator is 0, an unnormalized floating-point 1 
is entered into Si. 



HR-3005 



3-65 



INSTRUCTION 071 (continued) 



Instructions 071i30 through 071i70 are initially recognized by the 
assembler as the symbolic instruction Si exp. The assembler then checks 
the expression to see if it has any of the indicated forms. If it finds 
one of the instructions in the exact syntax shown, it generates the 
corresponding Cray machine instruction. If none of the indicated forms 
are found, instruction OAOijkm or O^lijkm is generated as previously 
described under the 040 instruction. These special forms allow more 
efficient instructions for entering commonly used values into Si. 

The syntax form Si 0.6 (071i30) is useful for extracting the integer 
part of a floating-point quantity (that is, fix) as illustrated in the 
examples. 

Example: 



I Code Generated 


Location 


Result 




| Operand | Comment 




1 1 


10 






120 135 


1071707 




S7 






1 1 
|A7 | 
l i 


1071717 




S7 






1 1 
|+A7 | 
1 i 


1071324 




S3 






1 1 
| +FA4 | 
i i 




FIX 


— 






1 1 
16 | 


1071630 




S.FIX 




|0.6 | 
i i 


1071240 




S2 






1 1 
|0.4 | 
i i 


1071350 




S3 






1 1 

11. 1 
1 i 


1071460 




S4 






1 1 

12. | 
I i 


1071570 




S5 






1 1 
14. | 




* 


Fix 


a 


i i 
floating-point number in SI 




* 


Separate 


integer and fractional parts 
1 i 


1071230 




S2 






1 1 
|0.6 | 
i i 


1062312 




S3 






1 1 
IS1+FS2 | 
l i 


1023130 




Al 






1 1 

| S3 |; Integer part 

1 i 


1063332 




S3 






1 1 

IS3-FS2 | ; Floating-poi 

| | ; integer part 
1 i 


1063113 




| SI 






1 1 

|S1-FS3 |; Fractional 

| | ; part 
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INSTRUCTIONS 072 - 075 









Machine | 


| Result 


Operand 


Description 


Instruction | 


1 Si 


RT 


Transmit (RTC) to Si 


072i00 | 


| Sit 


SM 


Read semaphore to Si 


072i02 | 


! Sit 


STj 


Read (STj) register to Si 


072ij3 | 


1 Si 


VM 


Transmit (VM) to Si 


073i00 | 


1 tt 




Read performance counter into 
Si 


073ill | 


1 tt 




Increment performance counter 


073i21 | 


1 tt 




Clear all maintenance modes 


073i31 | 


| sittt 


SRO 


Transmit (SRO) to Si 


073i01 | 


| SMt 


Si 


Load semaphores from Si 


073i02 | 


| STjt 


Si 


Transfer (Si) to STj 


073ij3 | 


1 Si 


Tj'fc 


Transmit (Tjk) to Si 


074ij7c | 


1 Tjfc 


Si 


Transmit (Si) to Tj* 


07 5 ijk | 



•f* This instruction is available when the numeric trait NUMCLSTR, 
which is specified on the CPU parameter of the CAL invocation 
statement, is greater than zero. 

ft Not currently supported 

fft This instruction is available through the logical trait STATRG 
specified on the CPU parameter of the CAL invocation statement, 



Instruction 072i00 enters the 64-bit contents of the real-time clock 
into register Si. The clock is increased by 1 each clock period. The 
real-time clock can be reset only when in monitor mode using instruction 
072i00. 

Instruction 072i02 enters the values of all of the semaphores into Si. 
The 32-bit SM register is left justified in Si with SM00 occupying the 
sign bit. 

Instruction 072ij3 enters the contents of register STj into register Si. 
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INSTRUCTIONS 072 - 075 (continued) 



Instruction 073i00 enters the 64-bit contents of the VM register into 
register Si. The VM register is normally read after having been set by 
instruction 1750jk. 

Instruction 073ill is used for performance monitoring and is priviledged 
to monitor mode. 

Instructions 073i21 and 073i31 are part of the SECDED maintenance mode 
functions and are executed only if the maintenance mode switch on the 
mainframe's control panel is on. 

Instruction 073i01 enters the contents of the Status register into Si. 

Instruction 073i02 sets the semaphores from 32 high-order bits of Si. 
SM00 receives the sign bit of Si. 

Instruction 073ij'3 transfers the contents of register Si into register 
STj, which is shared between the CPUs in the current cluster. 

Instruction 074ij& enters the contents of register Tjk into register Si. 

Instruction Q75ijk enters the contents of register Si into register Tjk. 



Example: 



Code Generated 


Location| Result 


Operand 


Comment 




1 110 


20 


35 


072700 


|S7 


RT 




072002 


|S0 


SM 




072602 


|S6 


SM 




072003 


|S0 


ST0 




072013 


|S0 


ST1 




073200 


|S2 


VM 




073001 


|S0 


SR0 




073301 


| S3 


SR0 




073002 


|SM 


SO 




073102 


|SM 


SI 
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INSTRUCTIONS 07 2 - 075 (continued) 



Example (continued) 



Code Generated 


Location| Resu 


It 


Operand 


Comment 




1 | 10 


20 


35 


073502 


|SM 




S5 




073003 


|ST0 




SO 




073103 


|ST0 




SI 




074306 


| S3 




T6 




074566 


|S5 




T66 




075306 


|T6 




S3 




075567 


|T67 




S5 
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INSTRUCTIONS 076 - 077 









Machine | 


Result 


Operand 


Description 


Instruction | 


Si 


Vj,A& 


Transmit (Vj, element (kk)) 
to Si 


016ijk | 


Vi,hk 


Sj 


Transmit (Sj) to Vi element (A&) 


077 ijk | 


Vi,A*f 





Clear element (kk) of register 
Vi 


OlliOk | 



f Special CAL syntax 



Instruction Q76ijk enters the contents of the element of Vj indicated by 
the contents of the low-order 6 bits of kk into Si. The second element 
(that is, element 1) is selected if the k designator is 0. 

Instruction 077 ijk transmits the contents of register Sj to an element 
of Vi as determined by the low-order 6 bits of the contents of kk. 
Element 1, the second element of Vi, is selected if the k designator 
is 0. 

Instruction OlliOk zeros element (kk) of register Vi. The low-order 6 
bits of kk determine which element is zeroed. The second element of 
register Vi is zeroed (that is, element 1) if the k designator is 0. 



Example: 



Code Generated 


Location 


Res 


ult 


Operand 


Comment 




1 


10 


20 


35 


076456 






S4 




V5,A6 




076456 




I 
J 
K 


S.I 




4 
5 
6 
V.J,A.K 




077167 






VI, 


A7 


S6 




077602 






V6, 


A2 
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INSTRUCTIONS 10ft - 13ft 











Machine 


| Result 


Operand 


Description 




Instruction 


1 Ai 


exp /Aft 


Read from ((Ah) + exp) 


to Ai 


lOhijkm 


! Ait 


exp,0 


Read from (exp) to Ai 




100 ij km 


! Ait 


exp, 


Read from (exp) to Ai 




100 ij km 


! Ait 


,Aft 


Read from (Aft) to Ai 




lOftiOOO 


| exp, Aft 


Ai 


Store (Ai) to (Aft) + exp 


llhijkm 


| exp, ot 


Ai 


Store (Ai) to exp 




110 ij km 


I exp,t 


Ai 


Store (Ai) to exp 




110 ijkm 


I ,Aftt 


Ai 


Store (Ai) to (Aft) 




llftiOOO 


1 Si 


exp, Aft 


Read from ((Ai) + exp) 


to Si 


12hijkm 


! Sit 


exp,0 


Read from (exp) to Si 




120 ijkm 


! Sit 


exp, 


Read from (exp) to Si 




120 ijkm 


! Sit 


,Aft 


Read from (Aft) to Si 




12fti000 


| exp, Ah 


Si 


Store (Si) to (Aft) + exp 


13ftijfan 


| exp,ot 


Si 


Store (Si) to exp 




130ijfcm 


1 exp,t 


Si 


Store (Si) to exp 




130 ijkm 


1 ,Aftt 


Si 


Store (Si) to (Aft) 




13fti000 



f Special CAL syntax 



For these instructions, only the value of the expression is used if the ft 
designator is or if a zero or blank field is used in place of Aft. Only 
the content of Aft is used if the expression is omitted. An expression, 
if present, must not have a parcel-address attribute or an assembly error 
occurs. 
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INSTRUCTIONS 10ft - 13ft (continued) 



Instructions lOhijkm through lOftiOOO load the low-order 24 bits of a 
memory word directly into an A register. The memory address is 
determined by adding the address in the register Aft to the expression 
value. Only the value of the expression is used if the ft designator is 
0, or a or blank field is used in place of Aft. Only the contents of 
Aft is used if the expression is omitted. An assembler error will occur 
if an expression has a parcel-address attribute. 

Instructions llhijkm through llftiOOO store 24 bits from register Ai 
directly into memory. The high-order bits of the memory word are 
zeroed. The memory address is determined by adding the address in 
register Aft to the expression value. 

Instructions llhijkm through 12fti000 load the contents of a memory word 
directly into an S register. The memory address is determined by adding 
the address in register Aft to the expression value. Only the value of 
the expression is used if the ft designator is or a zero or blank field 
is used in place of Aft. Only the contents of Aft is used if the 
expression is omitted. An assembler error will occur if an expression 
has a parcel-address attribute. 

Instructions IZhijkm through 13fti000 store the contents of register Si 
directly into memory. The memory address is determined by adding the 
address in register Aft to the expression value. 

Example: 



| Code Generated 


Location| Result 


Operand 


Comment 




1 110 


20 


35 


|1001 00004520+ 


|A1 




CONl,A0 




|1002 00004520+ 


|A2 




CON1,0 




|1013 00004521+ 


| A3 




C0N1+1,A1 




|1024 17777777+ 


|A4 




-1,A2 




|1005 00003000+ 


|A5 




ADDR, 




|1046 00004647+ 


|A6 




CON,A4 




|1046 00000000+ 


|A6 




|,A4 




|1061 00000001+ 


|A1 




|1,A6 




|1072 00000177+ 


|A2 




|0'177,A7 




|1101 00004520+ 


| CON1 


,A0 


| Al 
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Example: 



INSTRUCTIONS lOh - 137l (continued) 



Code Generated 


Location 


Result 


Operand 


Comment 




1 


10 


20 1 


35 


1102 00004520+ 




CON1,0 


A2 




1113 00004521+ 




C0N1+1,A1 


A3 




1124 17777777+ 




-1,A2 


A4 




1105 00003000+ 




ADDR, 


A5 




1146 00004647+ 




[CON,A4 


A6 




1146 00000000+ 




I /A4 


A6 




1161 00000001+ 




I1/A6 


Al 




1172 00000177+ 




|0'177,A7 


A2 




1201 00004520+ 




| SI 


CONl,A0 




1202 00004520+ 




|S2 


CON1,0 




1213 00004521+ 




| S3 


C0N1+1,A1 




1224 17777777+ 




|S4 


-1,A2 




1205 00003000+ 




|S5 


ADDR, 




1246 00004647+ 




|S6 


CON,A4 




1246 00000000+ 




|S6 


,A4 




1261 00000001+ 




| SI 


1,A6 




1272 00000177+ 




|S2 


0*177^7 




1301 00004520+ 




|CONl,A0 


SI 




1302 00004520+ 




|CON1,0 


S2 




1346 00000000+ 




|,A4 


S6 




1324 17777777+ 




I-1/A2 


S4 




1305 00003000+ 




|ADDR, 


S5 
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INSTRUCTIONS 140 - 147 











Machine | 


| Result 


Operand 




Description 


Instruction | 


1 Vi 


Sj&V* 


Logical 
(V*) to 


products of (Sj) and 
Vi 


140ij/c | 


| Vi 


VjSMk 


Logical 
(V*) to 


products of (Vj) and 
Vi 


141ijfc | 


1 Vi 


SjWk 


Logical 
to Vi 


sums of (Sj) and (Vk) 


142ij& | 


! Vit 


Vk 


Transmit (V*) to Vi 


142i0fc | 


1 vi 


V j ! V* 


Logical 
to Vi 


sums of (Vj) and (V*) 


143ij* | 


1 vi 


SjWk 


Logical 
(Vk) to 


differences of (Sj) and 
Vi 


144ij& j 


1 vi 


VjWk 


Logical 
(Vk) to 


differences of (Vj) and 
Vi 


14 5 ijfc | 


! vit 





Clear Vi 


145iii | 


1 vi 


Sj'Vfc&VM 


Vector merge of (Sj) and (Vk) 


146 ijk | 






to Vi 






! vit 


#VM&V* 


Vector merge of (Vk) and zero 


146i0* | 






to Vi 






1 vi 


Vj!V*&VM 


Vector merge of (Vj) and (Vk) 


147 ijk | 






to Vi 







f Special CAL syntax 



Instruction 140ij& forms the logical products of the contents of Sj and 
the contents of elements of Vk and enters the results into elements of 
Vi. If the j designator is 0, elements of register Vi are zeroed. The 
number of operations performed by this instruction is determined by the 
contents of the VL register. 
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INSTRUCTIONS 140 - 147 (continued) 

Instruction 141ij& forms the logical products of the contents of elements 
of register Vj and elements of register Vk and enters the results into 
elements of Vi. If the j designator is the same as the k designator, the 
contents of the Vj elements are transmitted to the Vi elements. 

The number of operations performed by this instruction is determined by 
the contents of the VL register. 

Instruction lA2ijk forms the logical sums of the contents of Sj and the 
contents of elements of Vk and enters the results into elements of Vi. 
The contents of the Vk elements are transmitted to the Vi elements if the 
j designator is 0. The VL register determines the number of operations 
performed by this instruction. 

Instruction 142i0fc transmits the contents of the elements of register Vk 
to the elements of register Vi . The VL register determines the number of 
elements performed by this instruction. 

Instruction lA3ijk forms the logical sums of the contents of elements of 
Vj and elements of Vk and enters the results into elements of Vi. 

If the j and k designators are equal, the contents of the Vj elements 
are transmitted to Vi. The VL register determines the number of 
operations performed by this instruction. 

Instruction lAAijk forms the logical differences of the contents of Sj 
and the contents of elements of Vk and enters the results into elements 
of Vi. If the j designator is 0, the contents of the Vk elements are 
entered into the Vi elements. The VL register determines the number of 
operations performed by this instruction. 

Instruction 145ij& forms the logical differences of the contents of 
elements of Vj and elements of Vk and enters the results into elements 
of Vi. If the j and k designators are equal, the Vi elements are 
zeroed. The VL register determines the number of operations performed 
by this instruction. 

Instruction 145iii zeros elements of Vi. The VL register determines the 
number of elements performed by this instruction. 

Instruction lA6ijk transmits the contents of Sj or the contents of 
element n of Vk to element n of Vi depending on the ones mask in the VM 
register. The content of Sj is transmitted if bit n of VM is 1; the 
content of element n of Vk is transmitted if bit n of VM is 0. 
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INSTRUCTIONS 140 - 147 (continued) 



Element n of Vi is if the j designator is and bit n of VM is 1. 
The VL register determines the number of operations performed by this 
instruction. 

Instruction 146i0fc zeroes element n of register Vi or transmits the 
contents of element n of Vk to element n of Vi depending on the ones 
mask in the VM register. If bit n of VM is 1, element n of Vi is 
zeroed; if bit n is 0, element n of Vk is transmitted. The VL register 
determines the number of operations performed by this instrction. 

Instruction 147ij£ transmits the contents of element n of Vj or element 
n of Vk to element n of Vi depending on the ones mask in the VM 
register. The content of the Vj element is transmitted if bit n of VM is 
1; the content of the Vk element is transmitted if bit n of VM is 0. The 
VL register determines the number of operations performed by this 
instruction. 

Instructions 140ij& through 147ij& execute in the Vector Logical 
functional unit. 

For these instructions (except 145iii), a warning level message is 
issued if the logical trait VRECUR is specified on the CPU parameter of 
the CAL invocation statement and either i=j or i=k (for V registers 
only) . A comment level message is issued of NOVRECUR is specified on the 
CPU parameter of the CAL invocation statement. 



Example: 



Code Generated 


Location| Result 


Operand 


Comment 




1 110 


20 


35 


140123 


|V1 


S2&V3 




141257 


|V2 


V5&V7 




141033 


|V0 


V3&V3 




142615 


|V6 


S1!V5 




142102 


|V1 


V2 




143714 


|V7 


V1!V4 




144267 


|V2 


S6W7 




145513 


|V5 


V1W3 




145500 


|V5 
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INSTRUCTIONS 140 - 147 (continued) 



Example (continued): 



Code Generated | Location | Result | Operand | Comment 

II | 10 [20 135 

III I 
146726 | |V7 |S2!V6&VM | 



For the above instruction, assume the following initial register 
conditions exist: 

(VL) = 4 

(VM) = 60000 0000 0000 0000 0000 

(S2) = -1 

Element of V6 = 1 

Element 1 of V6 = 2 

Element 2 of V6 = 3 

Element 3 of V6 = 4 

After instruction execution, the first four elements of V7 are modified 
as follows: 

Element of V7 = 1 

Element 1 of V7 = -1 

Element 2 of V7 = -1 

Element 3 of V7 = 4 

The remaining elements of V7 are unaltered. 

Example (continued): 

| Code Generated | Locationl Result | Operand | Comment 

I II HO 120 135 

I III I 

1146607 | |V6 |#VM&V7 | 



Assume the following initial register conditions for the above 
instruction: 

(VL) = 4 

(VM) = 50000 0000 0000 0000 0000 

Element of V7 = 1 

Element 1 of V7 = 2 

Element 2 of V7 = 3 

Element 3 of V7 = 4 
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INSTRUCTIONS 140 - 147 (continued) 



After instruction execution, the first four elements of V6 have been 
modified as follows: 

Element of V6 = 1 

Element 1 of V6 = 

Element 2 of V6 = 3 

Element 3 of V6 = 



Example (continued): 



| Code Generated | Locationl Result | Operand | Comment 

I II HO 120 135 

I III I 

1147123 | | VI |V2!V3&VM | 



Assume the following initial register conditions exist for the above 
instruction: 







(VL) 


= 


4 






(VM) 


= 


60000 0000 0000 0000 0000 


Element 





of V2 


= 


1 


Element 


1 


of V2 


= 


2 


Element 


2 


of V2 


= 


3 


Element 


3 


of V2 


= 


4 


Element 





of V3 


= 


-1 


Element 


1 


of V3 


= 


-2 


Element 


2 


of V3 


= 


-3 


Element 


3 


of V3 


= 


-4 



After instruction execution, the first four elements of Vi have been 
modified as follows: 

Element of VI = -1 

Element 1 of VI = 2 

Element 2 of VI = 3 

Element 3 of VI = -4 

The remaining elements of VI are unaltered. 
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INSTRUCTIONS 150 - 151 















Machine 


Re 


suit 


Operand 






Description 


Instruction 


Vi 




Vj<hk 


Shift 
to Vi 


(Vj) 


left (A*:) places 


150ij& 


vit 




Vj<l 


Shift 


(Vj) 


left one place to Vi 


150ij0 


vi 




Vj>hk 


Shift 
to Vi 


(VJ) 


right (kk) places 


151ij& 


vit 




Vj>l 


Shift 


(VJ) 


right one place to Vi 


151ij0 



f Special CAL syntax 



Instruction 150ijfc and its special form shift the contents of the 
elements of register Vj to the left by the amount specified by the 
contents of kk and enter the results into the elements of Vi. The VL 
register determines the number of elements performed by this 
instruction. For each element, the shift is end off with zero fill. 
Elements of Vi are zeroed if the shift count exceeds 63. Element 
contents are shifted left one place if the k designator is 0; this can 
be specified through the special form of the instruction. 

Instruction 151ijk and its special form shift the contents of the 
elements of register Vj to the right by the amount specified by the 
contents of Ak and enter the results into the elements of Vi . The VL 
register determines the number of elements performed by this 
instruction. For each element, the shift is end off with zero fill. 
Elements of Vi are zeroed if the shift count exceeds 63. Element 
contents are shifted right one place if the k designator is 0; a 
special form of the instruction accommodates this feature. 

Instructions 150ij& and 151ijk execute in the Vector Shift functional 
unit. 

For these instructions, a warning-level message is issued if the logical 
trait VRECUR is specified on the CPU parameter of the CAL invocation 
statement and i=j. A comment-level message is issued if NORECUR is 
specified on the CPU parameter of the CAL invocation statement. 
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INSTRUCTIONS 150 - 151 (continued) 



Example: 



Code Generated 


Locationl Res 


ult 


| Operand 


Comment 




1 110 




120 


35 


150123 


|V1 




|V2<A3 




150450 


|V4 




|V5<1 


; Left 1 place 


151341 


|V3 




|V4>A1 




151450 


|V4 




|V5>1 


; Right 1 place 
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INSTRUCTIONS 152 - 153 















Machine | 


Re 


suit 


Operand 




Description 


Instruction | 


Vi 




Vj,Vj<kk 


Double 
places 


shift (Vj) 
to Vi 


left (kk) 


152ij7c | 


Vit 




Vj,Vj<l 


Double 
to Vi 


shift (Vj) 


left one place 


152ij0 | 


vi 




Vj,Vj>hk 


Double 
places 


shift (Vj) 
to Vi 


right (A*) 


153ijfc | 


vit 




Vj,Vj>l 


Double 
place 1 


shift (Vj) 
to Vi 


right one 


153ij0 | 



f Special CAL syntax 



Instruction 152ijfc and its special form shift 128-bit quantities from 
elements of Vj by the amount specified in kk and enter the result into 
elements of Vi. Element n of Vj is concatenated with element n+1 and 
the 128-bit quantity is shifted left by the amount specified in kk. The 
shift is end off with zero fill. The high-order 64 bits of the results 
are transmitted to element n of Vi. 

The VL register determines the number of elements performed by this 
instruction. The last element of Vj, as determined by VL, is 
concatenated with 64 bits of zeros. The 128-bit quantities are shifted 
left one place if the k designator is 0; the special form of the 
instruction accommodates this feature. 

Instruction 153ijfc and its special form shift 128-bit quantities from 
elements of Vj by the amount specified in kk and enter the result into 
elements of Vi. Element n-1 of Vj is concatenated with element n and 
the 128-bit quantity is shifted right by the amount specified in kk. The 
shift is end off with zero fill. The low-order 64 bits are transmitted 
to element n of Vi. 

The VL register determines the number of elements performed by this 
instruction. The first element of Vj is concatenated with 64 bits of 
zeros. The 128-bit quantities are shifted right one place if the k 
designator is 0; the special form of the instruction accommodates this 
feature. 

Instructions 152ijk and 153ijk execute in the Vector Shift functional 
unit. 
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INSTRUCTIONS 152 - 153 (continued) 



For these instructions, a warning-level message is issued if the logical 
trait VRECUR is specified on the CPU parameter of the CAL invocation 
statement and i=j. A comment level message is issued if NORECUR is 
specified on the CPU parameter of the CAL invocation statement. 



Example: 



I Code Generated 



Location! Result 



| Operand 



Comment 



10. 



2SL 



JL5_ 



152541 



|V5 



|V4 / V4<A1 



Assume the following initial register conditions for the above 
instruction: 







(VL) 


= 


4 






(Al) 


= 


3 


Element 





of V4 


= 





Element 


1 


of V4 


= 





Element 


2 


Of V4 


= 


1 


Element 


3 


of V4 


= 


1 



00000 0000 0000 0000 0007 

60000 0000 0000 0000 0005 

00000 0000 0000 0000 0006 

60000 0000 0000 0000 0007 



After instruction execution, the first four elements of V5 have been 
modified as follows: 

Element of V5 = 00000 0000 0000 0000 0073 

Element 1 of V5 = 00000 0000 0000 0000 0054 

Element 2 of V5 = 00000 0000 0000 0000 0067 

Element 3 of V5 = 00000 0000 0000 0000 0070 

The remaining elements of V5 are unaltered. 
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INSTRUCTIONS 152 - 153 (continued) 



Example: 



I Code Generated | Location | Result | Operand | Comment 

I II HO 120 135 

I III I 

1153026 | |V0 |V2,V2>A6 | 



Assume the following initial register conditions for the above 
instruction. 

(VL) = 4 

(A6) = 3 

Element of V2 = 00000 0000 0000 0000 0017 

Element 1 of V2 = 60000 0000 0000 0000 0005 

Element 2 of V2 = 1 00000 0000 0000 0000 0006 

Element 3 of V2 = 1 60000 0000 0000 0000 0007 

After instruction execution, the first four elements of V0 have been 
modified as follows: 

Element of V0 = 00000 0000 0000 0000 0001 

Element 1 of V0 = 1 66000 0000 0000 0000 0000 

Element 2 of V0 = 1 30000 0000 0000 0000 0000 

Element 3 of V0 = 1 56000 0000 0000 0000 0000 



The remaining elements of V0 are unaltered. 
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INSTRUCTIONS 154 - 157 











Machine 


Result 


Operand 




Description 


Instruction 


Vi 


Sj+Vk 


Integer 
to Vi 


sums of (Sj) and (Vk) 


1 54 ijk 


Vi 


Vj+Vk 


Integer 
to Vi 


sums of (Vj) and (Vk) 


155 ij* 


Vi 


Sj-Vk 


Integer 
(V/c) to 


differences of (Sj) and 
Vi 


156 ij^ 


vit 


-V* 


Transmit twos complement of (Vk) 


156i0^ 






to Vi 






vi 


Vj-Vk 


Integer 
(V7c) to 


differences of (Vj) less 
Vi 


157ij/c 



f Special CAL syntax 



Instruction 154ij& adds the contents of Sj to each element of Vk and 
enters the results into elements of Vi. Elements of Vk are transmitted 
to Vi if the j designator is 0. 

The VL register determines the number of operations performed by this 
instruction. 

Instruction 155ijk adds the contents of elements of register Vj to the 
contents of corresponding elements of register Vk and enters the results 
into elements of register Vi. 

The VL register determines the number of operations performed by this 
instruction. 

Instruction 156ijk subtracts the contents of each element of Vk from the 

contents of register Sj and enters the results into elements of register 

Vi. The negative (twos complement) of each element of Vk is transmitted 
to Vi if the j designator is 0. 

The VL register determines the number of operations performed by this 
instruction. 
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INSTRUCTIONS 154 - 157 (continued) 



Instruction 156i0fc transmits the twos complement of the contents of 
elements of register V7c to the elements of register Vi . The VL register 
determines the number of elements performed by this instruction. 

Instruction 157ijk subtracts the contents of elements of register Vk 
from the contents of corresponding elements of register Vj and enters 
the results into elements of register Vi. 

The VL register determines the number of operations performed by this 
instruction. 

Instructions 154ijk through 157ijk execute in the Vector Integer Add 
functional unit. 

For these instructions, a warning-level message is issued if the logical 
trait VRECUR is specified on the CPU parameter of the CAL invocation 
statement and either i=j or i=k (for V registers only). A comment level 
message is issued if NOVRECUR is specified on the CPU parameter of the CAL 
invocation statement. 



Example: 



Code Generated 


Location| Resu 


It 


Operand 


Comment 




1 110 


20 


35 


154213 


|V2 




S1+V3 




155456 


|V4 




V5+V6 




156712 


|V7 




S1-V2 




156102 


|V1 




-V2 




157345 


|V3 




V4-V5 
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INSTRUCTIONS 160 - 167 















Machine | 


Result 


Operand 


Description 






Instruction | 


Vi 


Sj*FV& 


Floating-point 
and (V*) to Vi 


products 


of 


(Sj) 


160ij& | 


Vi 


Vj*FVk 


Floating-point 
and (V*) to Vi 


products 


of 


(Vj) 


161ij* | 


Vi 


Sj*HV* 


Half -precis ion 
floating-point 
and (V*) to Vi 


rounded 
products 


of 


(Sj) 


162ij* | 


Vi 


Vj*HV/c 


Half -precis ion 
floating-point 
and (V*) to Vi 


rounded 
products 


of 


(Vj) 


163ij* | 


Vi 


Sj*RV& 


Rounded floating-point 
of (Sj) and (Vk) to Vi 


products 


1 64 ijk | 


Vi 


Vj*RVk 


Rounded floating-point 
of (Vj) and (V&) to Vi 


products 


165ij* | 


Vi 


Sj*IVk 


2-f loating-point produc 
(Sj) and (V*) to Vi 


ts of 


166ij* | 


vi 


Vj*IV& 


2-f loating-point products of 
(Vj) and (V&) to Vi 


167 ijk | 



Instruction 160ijk forms the floating-point products of the contents of 
Sj and elements of Vk and enters the results into elements of Vi. The 
results are not normalized if either operand is unnormalized. The number 
of operations performed is determined by the contents of the VL register. 

Instruction 161ijk forms the floating-point products of the contents of 
elements of Vj and elements of Vk and enters the results into elements 
of Vi. The results are not normalized if either operand is unnormalized. 
The number of operations performed is determined by the contents of the 
VL register. 

Instruction 162ijk forms the half-precision rounded floating-point 
products of the contents of the Sj register and the contents of elements 
of the Vk register and enters the results into elements of Vi. The 
results are not normalized if either operand is unnormalized. The 
low-order 18 bits of the results are zeroed. 



HR-3005 



3-86 



INSTRUCTIONS 160 - 167 (continued) 



The number of operations performed by this instruction is determined by 
the contents of the VL register. This instruction can be used in a 
divide algorithm when only 30 bits of accuracy are required. 

Instruction 163ij'7c forms the half-precision rounded floating-point 
products of the contents of elements of the Vj register and elements of 
the Vk register and enters the results into elements of Vi. The results 
are not normalized if either operand is unnormalized. The low-order 18 
bits of the results are zeroed. 

The VL register determines the number of operations performed by this 
instruction. This instruction can be used in a divide algorithm when 
only 30 bits of accuracy are required. 

Instruction 164ij"7c forms the rounded floating-point products of the 
contents of the Sj register and the contents of elements of Vk and enters 
the results into elements of Vi. The results will not be normalized if 
either operand is unnormalized. The VL register determines the number of 
operations performed by this instruction. 

Instruction 165ij"7c forms the rounded floating-point products of the 
contents of elements of Vj and elements of Vk and enters the results 
into elements of Vi. The results will not be normalized if either 
operand is unnormalized. The VL register determines the number of 
operations performed by this instruction. 

Instruction 166ijk forms 2 minus the floating-point products of the 
contents of Sj and the contents of elements of Vk and enters the results 
into elements of Vi. The results are not normalized if either operand is 
unnormalized. The VL register determines the number of operations 
performed by this instruction. 

Instruction 167ijk forms 2 minus the floating-point products of contents 
of elements of Vj and elements of Vk and enters the results into elements 
of Vi. The results are not normalized if either operand is unnormalized. 
This instruction is used in the divide sequence. The VL register 
determines the number of operations performed by this instruction. 

Instructions 160ijk through 167ijk execute in the Floating-point 
Multiply functional unit. For these instructions, a warning-level 
message is issued if the logical trait VRECUR is specified on the CPU 
parameter of the CAL invocation statement and either i=j or i=k (for V 
registers only) . A comment-level message is issued if NORECUR is 
specified on the CPU parameter of the CAL invocation statement. 
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Example: 



INSTRUCTIONS 160 - 167 (continued) 



Code Generated 


Location| Result 


Operand 


Comment 




1 110 


20 


35 


160627 


|V6 


S2*FV7 




161123 


|V1 


V2*FV3 




162456 


|V4 


S5*HV6 




163712 


|V7 


V1*HV2 




164314 


|V3 


S1*RV4 




165567 


|V5 


V6*RV7 




166123 


|V1 


S2*IV3 




167456 


|V4 


V5*IV6 
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INSTRUCTION 170 - 173 











Machine | 


Result 


Operand 


Description 


Instruction | 


Vi 


Sj+FVfc 


Floating-point 
(Vk) to Vi 


sums of (Sj) and 


170 ijk | 


vit 


+FV& 


Normalize (V/c) 


to Vi 


170i0& | 


Vi 


Vj+FVk 


Floating-point 
(Vk) to vi 


sums of (Vj) and 


lllijk | 


vi 


Sj-FVfc 


Floating-point 
(Sj) less (Vfc) 


differences of 
to Vi 


lllijk | 


vit 


-FVfc 


Transmit normalized negative of 


llliQk | 






(Vk) to Vi 






vi 


Vj-FVk 


Floating-point 
(Vj) less (Vfc) 


differences of 
to Vi 


17 3 ij* | 



f Special CAL syntax 



Instruction HOijk forms the floating-point sums of the contents of Sj 
and elements of register Vk to elements of register Vi. The results are 
normalized even if the operands are unnormalized. The VL register 
determines the number of operations performed by this instruction. 

The special form of the instruction (170i0k) normalizes the contents of 
the elements of Vk and enters the results into elements of Vi . 

Instruction lllijk forms the floating-point sums of the contents of 
elements of Vj and elements of Vk and enters the results into the 
elements of register Vi . The results are normalized even if the operands 
are unnormalized. The number of operations performed is determined by 
the contents of the VL register. 

Instruction 112ijk forms the floating-point differences of the contents 
of Sj and elements of register Vk and enters the results into register 
Vi. The results are normalized even if the operands are unnormalized. 
The negatives (twos complements) of floating-point quantities in elements 
of V& are transmitted to Vi if the j designator is 0. The special form 
(172i0&) accommodates this special case. The number of operations 
performed is determined by the contents of the VL register. 



HR-3005 



3-89 



INSTRUCTION 170 - 173 (continued) 



Instruction ITSijk forms the floating-point differences of the contents 
of elements of register Vj less the contents of elements of registers Vk 
and enters the results into elements of register Vi. The results are 
normalized even if the operands are unnormalized. The VL register 
determines the number of operations performed by this instruction. 

Instructions IJOijk through ITiijk execute in the Floating-point Add 
functional unit. For these instructions, a warning level message is 
issued if the logical trait VRECUR is specified on the CPU parameter of 
the CAL invocation statement and either i=j or i=k (for V registers 
only). A comment level message is issued if NORECUR is specified on the 
CPU parameter of the CAL invocation statement. 



Example: 



Code Generated 


Location| Resu 


It 


Operand 


Comment 




1 1 10 


20 


35 


170712 


|V7 




S1+FV2 




170501 


|V5 




l+FVl 


; Normalize (V 
; to V5 


171234 


|V2 




|V3+FV4 




172516 


|V5 




IS1-FV6 




173712 


|V7 




|V1-FV2 
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INSTRUCTION 174 



| | | Machine 
Result | Operand | Description | Instruction 


Vi | /HVj | Floating-point reciprocal | 174ij0 
| | approximation of (Vj) to Vi | 



Instruction 174ij0 forms the approximations to the reciprocals of the 
floating-point values in elements of Vj and enters the results into 
elements of Vi. The results are meaningless if the contents of elements 
are unnormalized or 0. This instruction is used in the divide sequence. 
The VL register determines the number of operations performed by this 
instruction. 

Instruction 174ij0 executes in the Floating-point Reciprocal functional 
unit. For these instructions, a warning level message is issued if the 
logical trait VRECUR is specified on the CPU parameter of the CAL 
invocation statement and i=J. A comment level message is issued if 
NORECUR is specified on the CPU parameter of the CAL invocation statement, 



Example: 



Code Generated 


Location 


Result 




| Operand 




| Comment 




1 


10 






120 




| 35 




* 


Divide 


1 
elements of VI 


by 


1 
elements of V2; 




* 


Result 


to 


V6 




1 


174320 




V3 






|/HV2 
i 




1 
i 


161413 




V4 






1 

|V1*FV3 

1 




1 

1 
i 


167532 




V5 






1 

|V3*IV2 

i 




1 

1 
i 


161645 




V6 






1 
|V4*FV5 




1 

1 
i 




* 


Divide 


I 
elements of VI 


by 


1 
elements of V2; 




* 


Res 


ults 


> accurate to 30 bits, result to V6 


174320 




V3 






|/HV2 
i 




1 
i 


165613 




V6 






1 

|V1*HV3 

1 




1 

1 
1 




* 


Divide 


SI 


1 
by elements 


of 


1 
V2; Result to V6 


174320 




V3 






|/HV2 
1 




1 
1 
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INSTRUCTION 174 (continued) 



Example (continued) 



Code Generated 


Location| Resu 


It 


Operand 


Comment 




1 1 10 


20 


35 


160413 


|V4 




S1*FV3 




167532 


|V5 




V3*IV2 




161645 


|V6 




V4*FV5 
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INSTRUCTIONS 174ijl - 174ij2 























Machine 


Re 


suit 


Oper 


and 




Description 






Instruction 


Vit 




PVj 




Population 


count 


of 


(Vj) 


to 


(Vi) 


174ijl 


Vit 




QVj 




Population 


count 


parity 


of 


(vj) 


174 ij2 










to (Vi) 















f Vector Population Count; this instruction is available through the 
logical trait VPOP specified on the CPU parameter of the CAL 
invocation statement. 



Instruction 174ijl counts the number of 1 bits in the elements of 
register Vj and enters the result into the elements of register Vi. 
The VL register determines the number of elements performed by this 
instruction. 

Instruction 174ij2 enters a or 1 into the elements of Vi depending on 
whether the elements of Vj have an even or odd number of 1 bits. A is 
entered into element n of Vi if there is an even number of 1 bits in 
element n of Vj; a 1 is entered into element n of Vi if there is an odd 
number of 1 bits in element n of Vj. The number of elements involved is 
determined by the VL register. 

Instructions 174ijl and 174ij2 execute in the Reciprocal Approximation 
functional unit. For these instructions, a warning level message is 
issued if the logical trait VRECUR is specified on the CPU parameter of 
the CAL invocation statement and i=j . A comment level message is issued 
if NORECUR is specified on the CPU parameter of the CAL invocation 
statement. 



Example: 



Code Generated 


Location| Resu 


It 


|0per 


and 


Comment 




1 110 




120 




35 


174311 


|V3 




|PV1 




; Pop count of 
; VI to V3 


174522 


|V5 




IQV2 




; Pop count 
; parity of V2 
; to V5 
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INSTRUCTION 175 













Machine | 


| Result 


Operand 


Description 


Instruction | 


| VM 


vj,z 


Set VM bits 

vj 


for 


zero elements of 


17 50 JO | 


| VM 


Vj,N 


Set VM bits 
of Vj* 


for 


nonzero elements 


17 50J1 | 


| VM 


Vj,P 


Set VM bits 
elements of 


for 
VJ 


positive 


17 50J2 | 


| VM 


Vj,M 


Set VM bits 
elements of 


for 
VJ 


negative 


1750J3 | 


| Vi,VMt 


vj.z 


Set VM bits 


and 


register Vi 


175ij4 | 






to Vj, for ; 


zero 


elements of Vj 




| Vi,VMt 


VJ,N 


Set VM bits 


and 


register Vi to 


175ij5 | 






Vj, for nonzero 


elements of Vj 




| Vi,VMt 


Vj,P 


Set VM bits 


and 


register Vi to 


175ij6 | 






Vj, for positive elements of Vj 




| Vi,VMf 


VJ,M 


Set VM bits 


and 


register Vi to 


175ij7 | 






Vj, for negative elements of Vj 





f This instruction is available through the logical trait CIGS 
specified on the CPU parameter of the CAL invocation statement 



Instructions 1750j"0 through 1750j*3 create a mask in the VM register. 
The 64 bits of the VM register correspond to the 64 elements of Vj. 
Elements of Vj are tested for the specified condition. If the condition 
is true for an element, the corresponding bit is set to 1 in the VM 
register. If the condition is not true, the bit is zeroed. 

The number of elements tested is determined by the contents of the VL 
register; however, the entire VM register is zeroed before elements of Vj 
are tested. I.f the contents of an element is 0, it is considered 
positive. Element corresponds to bit 0, element 1 to bit 1, and so on, 
from left-to-right in the register. 
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INSTRUCTION 175 (continued) 



Instructions 175ij4 through 175ij7 create an identical vector mask as 
in the above instructions, and in addition create a compressed index list 
in register Vi based on the results of testing the contents of the 
elements of register Vj. 

These instructions execute in the Vector Logical functional unit. 



Example: 



Code Generated 


Location | Resu 


It 


| Operand 


Comment 




1 110 




120 


35 


175050 


|VM 




|V5,Z 




175061 


|VM 




|V6,N 




175072 


|VM 




|V7,P 




175013 


|VM 




|V1,M 
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INSTRUCTIONS 176 - 177 









Machine 


Result 


Operand 


Description 


Instruction 


Vi 


,A0,Afc 


Read from memory starting at 
(AO) increased by (A/c) and load 
into Vi 


176i0& 


Vit 


,A0,1 


Read from consecutive memory 
addresses starting with (AO) 
and load into Vi 


176i00 


vitt 


,hO,Vk 


Read from memory using memory 
address (AO) + (V&) and load 
into Vi 


176il& 


, AO , A/c 


vj 


Store (Vj) to memory starting 
at (AO) increased by (Ak) 


1770J& 


,A0,1 


vj 


Store (Vj) to memory in 
consecutive addresses starting 
with (AO) 


1770JO 


,A0,V*tt 


vj 


Store (Vj) to memory using 
memory address (AO) + (Vk) 


mijk 



jf Special CAL syntax 

ff This instruction is available through the logical trait CIGS 
specified on the CPU parameter of the CAL invocation statement 



Instruction 176i0k and 176i00 load words into elements of register Vi 
directly from memory. AO contains the starting memory address. This 
address is increased by the contents of register Ak for each word 
transmitted. The contents of A& can be positive or negative allowing 
both forward and backward streams of references. If the k designator is 
or if 1 replaces kk in the operand field of the instruction/ the 
address is increased by 1. 

The number of elements transferred is determined by the contents of the 
VL register. 

For instruction 176il&, register elements begin with and are increased 
by 1 for each transfer. The low-order 24 bits of each element of Vk 
contain a signed 24-bit integer which is added to (AO) to obtain the 
current memory address. 
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INSTRUCTIONS 17 6 - 177 (continued) 



The VL register determines the number of words transferred. 

Instructions 1770jk and 1770J0 store words from elements of register Vj 
directly into memory. AO contains the starting memory address. This 
address is increased by the contents of register Ak for each word 
transmitted. The contents of kk can be positive or negative allowing 
both forward and backward streams of references. If the k designator is 
or if 1 replaces Ak in the result field of the instruction, the address 
is increased by 1. 

The VL register determines the number of elements transferred. 

For instruction lllljk, register elements begin with and are increased 
by 1 for each transfer. The low-order 24 bits of each element of Vk 
contains a signed 24-bit integer which is added to (AO) to obtain the 
current memory address. 

The VL register determines the number of elements transferred. 



Example: 



Code Generated 


Location| Result 


Operand 


Comment 




1 | 10 


20 


35 


176201 


|V2 




,A0,A1 




176500 


|V5 




,A0,1 




177032 


I ,A0, 


A2 


V3 




177030 


I ,A0, 


1 


V3 
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SYMBOLIC INSTRUCTION SUMMARY 

This section contains symbolic instructions summary charts for the 
CRAY X-MP computer system. It also lists the functional units for the 
CRAY X-MP computer system. 



FUNCTIONAL UNITS 

Instructions other than simple transmits or control operations are 
performed by specialized hardware known as functional units. Each unit 
implements an algorithm or a portion of the instruction set. 

Functional Unit Instructions 

Address Integer Add 030, 031 

Address Integer Multiply 032 

Scalar Integer Add 060, 061 

Scalar Logical 042-051 

Scalar Shift 052-055 

056, 057 

Scalar Pop/Parity/ 026 

Leading Zero 027 

Vector Integer Add 154-157 

Vector Logical 140-147, 175 

Second Vector Logical 140-145 

Vector Shift 150, 151, 153 

152 

Vector Pop/Parity 174ijl, 174ij'2 

Floating-point Add 062, 063, 170-173 

Floating-point Multiply 064-067, 160-167 

Floating-point Reciprocal 070, 174ij0 

Memory (Scalar) 100-130 

100-130 

Memory (Vector) 176, 177 



f Multiprocessor CRAY X-MP computer systems 
ft Single-processor CRAY X-MP computer systems 
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CRAY X-MP SYMBOLIC MACHINE INSTRUCTIONS 







Logical Operations 






1 Si 


Sj&STc 


Vi 


Sj&vfc 


vi 




vj&Vfc 


1 Si 


Sj&SB 












1 Si 


SB&Sj 












1 Si 


#S&&Sj 












1 Si 


# SB&Sj 












1 Si 


S j ! Sk 


Vi 


Sj!V& 


vi 




VjWk 


1 Si 


S j ! SB 












1 Si 


SB ! S j 












1 Si 


Sj\S& 


Vi 


Sj\V/c 


vi 




vjwfc 


1 Si 


Sj\SB 












1 Si 


SB\Sj 












1 Si 


#Sj\S7c 












1 Si 


#Sj\SB 












1 Si 


#SB\Sj 
















VM 


vj,z 


vi, 


VM 


vj,z 






VM 


VJ,N 


vi, 


VM 


VJ,N 






VM 


VJ,P 


vi, 


VM 


vj,p 






VM 


Vj,M 


vi, 


VM 


Vj,M 


1 Si 


Sj!Si&S/c 












1 Si 


Sj.'Si&SB 


Vi 

vi 


S j ! V&&VM 
#VM&V& 


vi 




V j ! Vfc&VM 




Floating- 


point Operations 






| EFI 














| DFI 














1 Si 


Sj+FSk 


vi 


Sj+FVfc 


vi 


vj 


+FV£ 


1 Si 


+FSk 


vi 


+FV& 








1 Si 


Sj-FSk 


vi 


Sj-FVfc 


vi 


vj 


-FV& 


1 Si 


-FSk 


vi 


-FVfc 








1 Si 


Sj*FSk 


vi 


Sj*FV/c 


vi 


vj 


*FV/C 


1 Si 


Sj*ESk 


vi 


Sj*HVfc 


vi 


vj 


*HV& 


1 Si 


Sj*RSk 


vi 


Sj*RVk 


vi 


vj 


*RVfc 


1 Si 


Sj*ISk 


vi 


Sj*IVk 


vi 


vj 


*IV& 


1 Si 


/HSj 






vi 


/HVj 
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Shift Instructions 



SO Si < exp 

Si Si < exp 

Si Si,Sj<Ak 

Si Si,Sj<l 

Si Si<kk 

Vi vj<hk 

Vi vj<l 

vi vj,vj<hk 

vi vj,vj<i 



SO Si>exp 

Si Si>exp 

Si Sj,Si>Ak 

Si Sj,Si>l 

Si Si>Ak 

Vi Vj>Afc 

vi vj>i 

vi vj,vj>Ak 

vi vj,vj>i 



1 



Register Entry Instrucitons 



Ah exp 
Ai -1 

Si exp 



Si 





Si 


1 


Si 


-1 


Si 


1 


Si 


2 


Si 


4 


Si 


0.4 


Si 


0.6 



Si <exp 

Si #>exp 

Si >exp 

Si #<exp 

Si SB 

Si #SB 

Vi,Ak 
vi 

SMjk 1,TS 
SMjfc 
SMJ& 1 



Program Branches and Exits 



Bit Count Instructions 



exp 
Bjk 



JAZ exp 
JAN exp 
JAP exp 
jam exp 



exp 



EX 

PASS 



JSZ exp 

JSN exp 

JSP exp 

JSM exp 



ERR 



Ai PSj 
Ai QSj 
Ai zsj 



vi pvj 
Vi QVj 



Monitor Operations 



CA,Aj 


Ak 


CCI 


CL,Aj 


Ak 


ECI 


CI,Aj 




DC I 


MC , A J 




ERI 


XA 


Aj 


DRI 


RT 


SJ 


CLN 


PCI 


sj 




SIPI 


exp 




SIPI 






CIPI 







exp 



1 



Integer Arithmetic Operations 



Ai Aj+Ak 

Ai Aj+1 

Ai Aj-Ak 

Ai Aj-1 

Ai Aj*Ak 



Si Sj'+S7c 
Si Sj-S* 



Vi Sj+V* 
Vi Sj-V^ 



Vi vj+Vk 
Vi vj-V* 
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Inter-register Transfers 



Memory Transfers 



Ai 


kk 


Si 


Sk 


Ai 


-Ak 


Si 


-Sk 






Si 


#S& 


Ai 


sj 


Si 


A* 






Si 


+A/c 


Ai 


VL 


Si 


+FAk 


Ai 


Bjk 


Si 


Tjk 


Ai 


SBJ 


Si 


STJ 


Ai 


CI 


Si 


Vj,hk 


Ai 


CA,Aj 


Si 


VM 


Ai 


CE,Aj 


Si 


RT 






Si 


SM 






Si 


SRj 


Bjk 


Ai 


ijk 


Si 


SBj 


Ai 


STj 


Si 






Vi 


V* 






Vi 


-Vk 






vi,Ak 


Sj 


VL 


A* 


VM 


Sj 


VL 


1 


VM 






DBM 
EBM 
CMR 

(store) 
,A0 Bjk,Ai 
0,A0 Bjk,Ai 



,A0 
0,A0 



1jk,Ai 
ljk,Ai 



SM 



Si 



exp, Ah Ai 

exp,0 Ai 

exp, Ai 

,Ah Ai 

exp, Ah Si 

exp,0 Si 

exp, Si 

,Ah Si 

,A0,Ak V j 

,A0,1 Vj 

,AQ,Vk Vj 

_ _ 1 



(load) 
BJk,Ai ,A0 
BJk,Ai 0,A0 

Tjk,Ai ,A0 
1jk,Ai 0,A0 



Ai 
Ai 
Ai 
Ai 

Si 
Si 
Si 
Si 

Vi 
vi 

vi 



exp, Ah 
exp,0 
exp, 
,Ah 

exp, Ah 
exp,0 
exp, 
,Ah 

,A0,Ak 
,A0,1 

,A0,vk 



Register 


Value 


Ah, h=0 





Ai, i=0 


(AO) 


Aj, j=0 





A*, k=0 


1 


Si, i=0 


(SO) 


Sj, j=0 





S&, *=0 


2 63 



Logical Operators 



& 0101 

AND 1100 

0100 



OR 



0101 
1100 
1101 



\ 0101 

XOR 1100 

1001 
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FUNCTIONAL INSTRUCTION SUMMARY 

This subsection contains an instruction summary, listed by function, for 
the CRAY X-MP computer system. A detailed description can be found on 
the referenced pages. 



REGISTER ENTRY INSTRUCTIONS 

Instructions in this category provide for entering values such as 
constants, expression values, or masks directly into registers. 



Entries into A registers 



Machine 
Instruction 

Olhijkm 



020ijkm or 
021ijkm or 
02 2 ijk 

031i00t 



CAL 



Aft exp 



Ai exp 



Ai -1 



Description Page 

Transmit ijkm to Aft; where the 3-31 
high-order bit of i is 1 

Enter exp into Ai 3-32 



Enter -1 into Ai 3-38 



Entries into S registers 



Machine 
Instruction 

040 ijkm or 
QAlijkm 

042i00t 

04 2 ijk 

04 2 ijkf 



CAL 
Si exp 

Si -1 
Si <exp 
Si #>exp 



Description 
Enter exp into Si 



Page 
3-45 



Enter -1 into Si 3-46 

Form ones mask in Si from right 3-46 
Form zeros mask in Si from left 3-46 



f Special CAL syntax 
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Machine 
Instruction 

042i77t 

043i00t 

04 3 ijk 

043ijfct 

047i00t 

051i00t 
071130 

071140 
071i50 
071i60 
071i70 



CAL 
Si 1 
Si 
Si >exp 
Si #<exp 

Si #SB 

Si SB 
Si 0.6 

Si 0.4 
Si 1. 
Si 2. 
Si 4. 



Description 










Paqe 


Enter 1 into Si 










3-46 


Clear Si 










3-46 


Form ones mask : 


Ln 


Si 


from 


left 


3-46 


Form zeros mask 


in 


l Si 


from 




3-46 



right 

Enter ones complement of sign 3-49 
bit in Si 

Enter sign bit into Si 3-49 

Enter 0.75*(2**48) into Si 3-65 
as normalized floating-point 
constant 

Enter 0.5 into Si as normalized 3-65 
floating-point constant 

Enter 1 into Si as normalized 3-65 
floating-point constant 

Enter 2 into Si as normalized 3-65 
floating-point constant 

Enter 4 into Si as normalized 3-65 
floating-point constant 



Entries into V registers 



Machine 
Instruction 

077i0*t 



145iiit 



CAL 



Vi,A/c 



Vi 



Description 



Clear Vi 



p age 



Clear element (A7c) of register 3-70 
Vi 



3-74 



f Special CAL syntax 
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Entries into Semaphore registers 



Machine 
Instruction 

0034jfc 
0036 jk 
0037jk 



CAL Description 

SMjk 1,TS Test and set semaphore jk, 
0<_jk<31 (decimal) 

SMjk Clear semaphore jk, 
0<_jk<_31 (decimal) 

SMjk 1 Set semaphore jk, 
0<_jk<^31 (decimal) 



Pa ge 
3-23 

3-23 

3-23 



INTER-REGISTER TRANSFER INSTRUCTIONS 

Instructions in this category provide for transferring the contents of 
one register to another register. In some cases, the register contents 
can be complemented, converted to floating-point format, or sign extended 
as a function of the transfer. 



Transfers to A registers 



Machine 






Instruction 


CAL 


02 3 i JO 


Ai 


Sj 


023201 


Ai 


VL 


24 ij& 


Ai 


Bjk 


026ij7 


Ai 


SBJ 


030i0Jct 


Ai 


A* 


031iO&t 


Ai 


-A* 


033100 


Ai 


CI 


03 3 i JO 


Ai 


CA,Aj 


033ijl 


Ai 


CE,Aj 



Description Page 

Transmit (Sj) to Ai 3-34 

Transmit (VL) to Ai 3-34 

Transmit (Bjk) to Ai 3-3 5 

Transfer (SBj) to Ai 3-36 

Transmit (kk) to Ai 3-38 

Transmit negative of (Ak) to Ai 3-38 

Channel number of highest 3-41 
priority interrupt request to Ai 

Address of channel (Aj) to Ai 3-41 
(J*0) 

Error flag of channel (Aj) to Ai 3-41 



t Special CAL syntax 
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Transfers to S registers 



Machine 
Instruction 

025ijk 

027ij7 

047i0fct 



071il& 

Qlli2k 

072100 
072102 
072ij3 
073100 
073i01 
07 3ij3 
074ij/c 
075ijk 
07 6 ijk 



CAL 
Bjk Ai 
SBj Ai 
Si #S& 



051i0fct Si Sk 

061i0&t Si -S* 

OlliOk Si Ak 



Si +Ak 

Si +FAk 

Si RT 
Si SM 
Si STj 
Si VM 
Si SRO 
STj Si 
Si Tjk 
Ijk Si 
Si Vj,Ak 



Description Page 

Transmit (Ai) to Bjk 3-35 

Transfer (Ai) to SBj 3-37 

Transmit ones complement of 3-49 
(Sk) to Si 

Transmit (Sk) to Si 3-49 

Transmit negative of (Sk) to Si 3-58 

Transmit (Ak) to Si without sign 3-65 
extension 

Transmit (Ak) to Si with sign 3-65 
extension 

Transmit (Ak) to Si as an 3-65 
unnormalized floating-point value 

Transmit (RTC) to Si 3-67 

Read semaphore to Si 3-67 

Read (STj) register to Si 3-67 

Transmit (VM) to Si 3-67 

Transmit (SRO) to Si 3-67 

Transfer (Si) to STj 3-67 

Transmit (Tjk) to Si 3-67 

Transmit (Si) to Tjk 3-67 

Transmit (Vj, element (Ak)) 3-70 
to Si 



f Special CAL syntax 
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Transfers to V registers 



Machine 
Instruction 

Qllijk 

142i0&t 

156i0&t 



CAL 

Vi,kk Sj 
Vi V* 
Vi -Vk 



Description Page 

Transmit (Sj) to Vi element (kk) 3-70 

Transmit (V*) to Vi 3-74 

Transmit twos complement of 3-84 
(Vk) to Vi 



Transfer to Vector Mask register 



Machine 






Instruction 


CAL 


Description 


0030J0 


VM Sj 


Transmit (Sj) to VM 


003000t 


VM 


Clear VM 



Page 
3-23 
3-23 



Transfer to Vector Length register 



Machine 






Instruction 


CAL 


Description 


00200* 


VL kk 


Transmit (kk) to VL 


002000t 


VL 1 


Enter 1 into VL 



Page 
3-19 
3-19 



Transfer to Semaphore register 



Machine 
Instruction 

073i02 



CAL 



SM Si 



Description 

Load semaphores from Si 



Page 
3-67 
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HR-3005 



3-106 



MEMORY TRANSFERS 

This category contains instructions that transfer data between registers 
and memory, enable and disable concurrent block memory transfers, and 
assure completion of memory references. 



Bidirectional memory transfers 



Machine 
Instruction 

002500 



002600 



CAL 



DBM 



EBM 



Description 

Disable bidirectional memory 
transfers 

Enable bidirectional memory 
transfers 



Page 
3-21 

3-21 



Memory references 

Machine 
Instruction 

002700 



CAL 



CMR 



Description 

Complete memory references 



Page 
3-21 



Stores 

Machine 
Instruction 

035 ijk 
035ij*t 
037 ijk 
037ijfct 



CAL Description Page 

,A0 Bjk, hi Store (Ai) words starting at 3-42 

Bjk to memory starting at (A0) 

0,A0 Bjk, hi Store (Ai) words starting at 3-42 

Bjk to memory starting at (A0) 

,A0 Ijk, hi Store (Ai) words starting at 3-42 

Ijk to memory starting at (A0) 

0,A0 Tjk,Ai Store (Ai) words starting at 3-42 

Ijk to memory starting at (A0) 
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Machine 
















Instruction 


CAL 


Description 






Page 


llhijkm 


exp, Ah Ai 


Store 1 


Ai) 


to 


(Ah) + 


exp 


3-71 


llhiOOot 


,Ah Ai 


Store ( 


Ai) 


to 


(A7i) 




3-71 


1 10 ijkwfr 


exp,0 Ai 


Store 


Ai) 


to 


exp 




3-71 


110 ijknfi 


exp, Ai 


Store 


'Ai) 


to 


exp 




3-71 


13hijkm 


exp,Ah Si 


Store 1 


r Si) 


to 


(Ah) + 


exp 


3-71 


130 ijxmt 


exp,0 Si 


Store < 


Si) 


to 


exp 




3-71 


130 ijknfi 


exp, Si 


Store 


[Si) 


to 


exp 




3-71 


13/ji000t 


,Ah Si 


Store 


[Si) 


to 


(Ah) 




3-71 


1770J& 


,A0,Ax Vj 


Store 


'Vj) 


to 


memory 


starting 


3-96 






at (A0 


increased by 


(A*) 





1770J0 



mijk 



,A0,1 Vj Store (Vj) to memory in 

consecutive addresses starting 
with (A0) 

,AQ,Vk Vj Store (Vj) to memory using 
memory address (A0) + (Vfc) 



3-96 



3-96 



Loads 

Machine 
Instruction 

034ijx 
034ijfcf 
036ij& 
036 ijkf 



CAL Description Page 

Bjk,hi ,A0 Read (Ai) words starting at 3-42 
Bjk from memory starting at (A0) 

Bjk f ki 0,A0 Read (Ai) words starting at 3-42 
Bjk from memory starting at (A0) 

Tjk,hi ,A0 Read (Ai) words starting at 3-42 
Tjk from memory starting at (A0) 

Tjk,hi 0,A0 Read (Ai) words starting at 3-42 
Tjk from memory starting at (A0) 
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Machine 
Instruction 

lOhijkm 

lohiooot 

100 ijkmf 
100 ijknft 
12hijkm 
120 ijknft 
120 ijknft 
12fti000t 
176i0fc 

176i00t 
n6ilk 



CAL Description Page 

hi exp,Ah Read from ((Ah) + exp) to Ai 3-71 

Ai ,Ah Read from (Ah) to Ai 3-71 

Ai exp,0 Read from (exp) to Ai 3-71 

Ai exp. Read from (exp) to Ai 3-71 

Si exp, Ah Read from ((Ai) + exp) to Si 3-71 

Si exp,0 Read from (exp) to Si 3-71 

Si exp Read from (exp) to Si 3-71 

Si ,Ah Read from (Ah) to Si 3-71 

Vi ,A0,A/c Read from memory starting at 3-96 
(A0) increased by (Ak) and 
load into Vi 

Vi /A0/1 Read from consecutive memory 3-96 
addresses starting with (A0) 
and load into Vi 

Vi ,AQ,Vk Read from memory using memory 3-96 
address (A0) + (Vk) and load 
into Vi 



INTEGER ARITHMETIC OPERATIONS 

Integer arithmetic operations obtain operands from registers and return 
results to registers. No direct memory references are allowed. 

The assembler recognizes several special syntax forms for increasing or 
decreasing register contents, such as the operands Ai+1 and Ai-1; 
however, these references actually result in register references such 
that the 1 becomes a reference to Ak with k=0 . 

All integer arithmetic, whether 24-bit or 64-bit, is twos complement and 
is so represented in the registers. The Address Add functional unit and 



f Special CAL syntax 
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Address Multiply functional unit perform 24-bit arithmetic. The Scalar 
Add functional unit and the Vector Add functional unit perform 64-bit 
arithmetic. 

No overflow is detected by Integer functional units. 

Multiplication of two fractional operands can be accomplished using the 
floating-point multiply instruction. The Floating-point Multiply 
functional unit recognizes conditions in which both operands have zero 
exponents as a special case and returns the high-order 48 bits of the 
result as an unnormalized fraction. Division of integers requires that 
they first be converted to floating-point format and then divided using 
the floating-point units. 



24-bit integer arithmetic 



Machine 
Instruction 

30 ijk 



CAL 



Ai Aj+Ak 



Description 

Integer sum of (Aj) and (Ak) 
to Ai 



Page 
3-38 



030ij"ot 



Ai Aj'+l 



Integer sum of (Aj) and 1 to 
Ai 



3-38 



031ij* 



031ij'ot 



Ai Aj-Ak 



Ai Aj-1 



Integer difference of (Aj) less 3-38 

(Ak) to Ai 

Integer difference of (Aj) less 3-38 
1 to Ai 



03 2 ijk 



Ai Aj*Ak 



Integer product of (Aj) and 
(Ak) to Ai 



3-40 



64-bit integer arithmetic 



Machine 
Instruction 

060ij& 



CAL Description 

Si Sj+Sk Integer sum of (Sj) and (Sk) 

to Si 



Page 
3-58 



061ij& 



Si Sj-Sk 



Integer difference of (Sj) less 
(Sk) to Si 



3-58 
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Machine 
Instruction 

1 54 ijk 
155 ijk 
156ijk 
157 ijk 



CAL 

Vi Sj+Vk 

Vi Vj+Vk 

Vi Sj-Vk 

vi vj-vfc 



Description Page 

Integer sums of (Sj) and (V7c) 3-84 
to Vi 

Integer sums of (Vj) and (V&) 3-84 
to Vi 

Integer differences of (Sj) and 3-84 
(Vk) to Vi 

Integer differences of (Vj) less 3-84 
(V*) to Vi 



FLOATING-POINT ARITHMETIC 

All floating-point arithmetic operations use registers as the source of 
operands and return results to registers. 

Floating-point numbers are represented in a standard format throughout 
the CPU. This format is a packed representation of a binary coefficient 
and an exponent or power of 2. The coefficient is a 48-bit signed 
fraction. The sign of the coefficient is separated from the rest of the 
coefficient. Since the coefficient is signed magnitude, it is not 
complemented for negative values. 



Floating-point range errors 



Machine 
Instruction 

002100 

002200 



CAL 
EFI 
DFI 



Description Page 

Enable floating-point interrupt 3-21 
Disable floating-point interrupt 3-21 



Floating-point addition and subtraction 



Machine 
Instruction 

062 ijk 



CAL Description 

Si Sj+FSk Floating-point sum of (Sj) 

and (Sk) to Si 



Page 
3-59 



HR-3005 



3-111 



Machine 
Instruction 

062i0fct 
063ij& 

063i0&t 

noijk 

noioki 
niijk 

112ijk 

172i0kf 

17 3 ijk 



CAL Description Page 

Si +FSk Normalize (Sk) to Si 3-59 

Si Sj-FSk Floating-point difference of 3-59 

(Sj) less (Sk) to Si 

Si -FSk Transmit the negative of (Sk) 3-59 

as a normalized floating-point 
value 

Vi Sj+FVk Floating-point sums of (Sj) 3-89 

and (V&) to Vi 

Vi +FVk Normalize (Vk) to Vi 3-89 

Vi VJ+FVk Floating-point sums of (Vj) 3-89 

and (Vk) to Vi 

Vi Sj-FVk Floating-point differences of 3-89 

(Sj) less (V*) to Vi 

Vi -FV& Transmit normalized negative of 3-89 
(Vk) to Vi 

Vi Vj-FVk Floating-point differences 3-89 

of (Vj) less (Vk) to Vi 



Floating-point multiplication 



Machine 
Instruction 

064ij& 



065ij& 



06 6 ijk 



CAL 

Si Sj*FS& 

Si Sj*HSfc 
Si Sj*RS& 



Description Page 

Floating-point product of (Sj) 3-61 
and (Sk) to Si 

Half-precision rounded floating- 3-61 
point product of (Sj) and (Sk) 
to Si 

Rounded floating-point product 3-61 
of (Sj) and (S&) to Si 
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Machine 
Instruction 

160ijk 
161 ijk 
16 2 ijk 

163ijk 

164ij/c 
165ijk 



CAL Description Page 

Vi Sj*FVk Floating-point products of (Sj) 3-86 

and (V&) to Vi 

Vi Vj*FVk Floating-point products of (Vj) 3-86 

and (V&) to Vi 

Vi Sj*HVfc Half-precision rounded floating- 3-86 
point products of (Sj) and (V&) 
to Vi 

Vi Vj*HV& Half-precision rounded floating- 3-86 
point products of (Vj) and (Vk) 
to Vi 

Vi Sj*RVk Rounded floating-point products 3-86 

of (Sj) and (Vk) to Vi 

Vi Vj*RV& Rounded floating-point products 3-86 
of (Vj) and (V&) to Vi 



Reciprocal iteration 



Machine 
Instruction 

067ijfc 



166ij& 



161ijk 



CAL 



Si Sj*IS7c 



Vi Sj*IV& 



Vi Vj*IV& 



Description 

2-f loating-point product of 
(Sj) and (S&) to Si 

2-f loating-point products of 
(Sj) and {Vk) to Vi 

2-f loating-point products of 
(Vj) and (V*) to Vi 



Page 
3-61 

3-86 

3-86 



Reciprocal approximation 



Machine 
Instruction 

070ij0 



174ij0 



CAL 

Si /HSj 

Vi /HVj 



Description 

Floating-point reciprocal 
approximation of (Sj) to Si 

Floating-point reciprocal 
approximation of (Vj) to Vi 



Page 
3-63 

3-91 
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LOGICAL OPERATIONS 

The Scalar and Vector Logical functional units perform bit-by-bit 
manipulation of 64-bit quantities. Operations provide for logical 
products, logical differences, logical sums, logical equivalence, and 
merges . 

A logical product (& operator) is the AND function. 

A logical difference (\ operator) is the EXCLUSIVE OR function. 

A logical sum (! operator) is the INCLUSIVE OR function. 

A logical merge combines two operands depending on a ones mask in a third 
operand. The result is defined by (operand 2 & mask) ! (operand 1 & #mask). 



Logical products 

Machine 
Instruction 

044ij& 

044ijot 
044ijot 
045ij7c 

045ijot 
140ijfc 

141ij& 



CAL Description Page 

Si Sj&S/c Logical product of (Sj) and 3-48 
(Sk) to Si 

Si SJ&SB Sign bit of (Sj) to Si 3-48 

Si SB&Sj Sign bit of (Sj) to Si; j*0 3-48 

Si #Sfc&Sj Logical product of (Sj) 3-48 
and #(S&) to Si 

Si #SB&Sj (Sj) with sign bit cleared to Si 3-48 

Vi Sj&Vk Logical products of (Sj) and 3-74 

(Vk) to Vi 

Vi Vj&Vfc Logical products of (Vj) and 3-74 
(V&) to Vi 
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Logical sums 

Machine 
Instruction 

051ijk 



14 2 ijfc 



14 3 ijk 



CAL 

Si Sj\Sk 



051ij'ot Si Sj.'SB 



051ij'ot Si SB'Sj 



Vi Sj'VTc 



Vi Vj!V& 



Description 



Pag_e 



Logical sum of (Sj) and (Sfc) to 3-49 
Si 

Logical sum of (Sj) and sign bit 3-49 
to Si 

Logical sum of sign bit and (Sj) 3-49 
to Si; j*0 

Logical sums of (Sj) and (Vk) 3-74 

to Vi 

Logical sums of (Vj) and (Vk) 3-74 

to Vi 



Logical differences 

Machine 
Instruction 



046ijfc 



144ij& 



145ij& 



CAL 



Si Sj\Sk 



046ijot si Sj\SB 



046ijot si SB\Sj 



Vi SjWk 



Vi VjWk 



Description 



Enter (Sj) into Si with sign 
bit toggled 

Enter (Sj) into Si with sign 
bit toggled; j'^0 



Page 



Logical differences of (Sj) and 3-48 
(S&) to Si 



3-48 



3-48 



Logical differences of (Sj) and 3-74 
(Vk) to Vi 

Logical differences of (Vj) and 3-74 
(V*) to Vi 



t Special CAL syntax 
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Logical equivalence 



Machine 
Instruction 

047ijfc 

047ijot 

047ijot 



CAL Description Page 

Si #Sj\SA Logical equivalence of (Sj) and 3-48 
(Sk) to Si 

Si #Sj\SB Logical equivalence of (Sj) and 3-48 
sign bit to Si 

Si #SB\Sj Logical equivalence of sign bit 3-48 
and (Sj) to Si; j^O 



Vector mask 




Machine 




Instruction 


CAL 


1750J0 


VM VJ,Z 


1750J1 


VM VJ,N 


1750J2 


VM VJ,P 


1750J3 


VM Vj,M 


175ij4 


Vi,VM vj,z 


175ij5 


Vi,VM VJ,N 


17 5ij6 


Vi,VM vj,p 


17 5ij7 


Vi,VM VJ,M 



Description 



Pag^e 



Set VM bits for zero elements of 3-94 
Vj 

Set VM bits for nonzero elements 3-94 
of Vj 

Set VM bits for positive elements 3-94 
of Vj 

Set VM bits for negative elements 3-94 
of Vj 

Set VM bits and register Vi to 3-94 
Vj, for zero elements of Vj 

Set VM bits and register Vi to 3-94 
Vj, for nonzero elements of Vj 

Set VM bits and register Vi to 3-94 
Vj, for positive elements of Vj 

Set VM bits and register Vi to 3-94 
Vj, for negative elements of Vj 
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Merge 

Machine 
Instruction CAL Description Page 

050ijk Si Sj!Si&S& Scalar merge of (Si) and (Sj) 3-49 

to Si 

050ijot si Sj!Si&SB Scalar merge of (Si) and sign 3-49 

bit of (Sj) to Si 

14 6 ijk Vi Sj!Vfc&VM Vector merge of (Sj) and 3-74 

(V/c) to Vi 

146i0&t vi #VM&V& Vector merge of (Vk) and zero 3-74 

to Vi 

147 ijk Vi Vj!V&&VM Vector merge of (Vj) and (Vk) 3-74 

to Vi 



SHIFT INSTRUCTIONS 

The Scalar Shift functional unit and Vector Shift functional unit shift 
64-bit quantities or 128-bit quantities. A 128-bit quantity is formed by 
concatenating two 64-bit quantities. The number of bits a value is 
shifted left or right is determined by the value of an expression for 
some instructions and by the contents of an A register for other 
instructions. If the count is specified by an expression, the value of 
the expression must not exceed 64. 

Machine 
Instruction CAL Description Page 

052ijk SO Si<exp Shift (Si) left exp places 3-54 

to SO 

053ij& SO Si>exp Shift (Si) right exp places 3-54 

to SO 

054ij& Si Si<exp Shift (Si) left exp places 3-54 

to Si 

055ij& Si Si>exp Shift (Si) right exp places 3-54 

to Si 

056ij& Si Si,Sj<A& Left shift by (Ak) of (Si) 3-56 

and (Sj) to Si 



f Special CAL syntax 
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Machine 
Instruction 

056 i jot 

056i0/ct 

57 ijk 

057ijot 

057i0/ct 

150ijk 

150ijot 

151ij& 

151ij0t 
15 2 ijk 

152ijot 

15 3 ijk 

153ijot 



CAL Description Page 

Si Si,Sj<l Left shift by 1 of (Si) and 3-56 
(Sj) to Si 

Si Si<kk Left shift by (A*) of (Si) to 3-56 

Si 

Si Sj,Si>A& Right shift by (Ak) of (Sj) 3-56 
and (Si) to Si 

Si Sj,Si>l Right shift by 1 of (Sj) 3-56 

and (Si) to Si 

Si Si>A/c Right shift by (A/c) of (Si) to 3-56 
Si 

Vi Vj<A/c Shift (Vj) left (kk) places to Vi 3-79 

Vi Vj<l Shift (Vj) left one place to Vi 3-79 

Vi Vj>kk Shift (Vj) right (kk) places 3-79 

to Vi 

Vi Vj>l Shift (Vj) right one place to Vi 3-79 

Vi Vj,Vj<A/c Double shift (Vj) left (kk) 3-81 

places to Vi 

Vi Vj,Vj<l Double shift (Vj) left one 3-81 
place to Vi 

Vi Vj,Vj>Ak Double shift (Vj) right (A/c) 3-81 

places to Vi 

Vi Vj,Vj>l Double shift (Vj) right one 3-81 
place to Vi 



BIT COUNT INSTRUCTIONS 

This category of instructions provides for counting the number of bits in 
an S or V register or counting the number of leading bits in an S or V 
register. 



t Special CAL syntax 
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Scalar population count 



Machine 
Instruction 

02 6 i jO 



CAL 



Ai PSj 



Description Page 

Population count of (Sj) to hi 3-36 



Vector population count 



Machine 
Instruction 

174ijl 



CAL 



Vi PVj 



Description Page 

Population count of (Vj) to (Vi) 3-93 



Scalar population count parity 



Machine 
Instruction 

026ijl 



174ij2 



CAL 



Ai QSj 



Vi QVj 



Description Page 

Population count parity of (Sj) 3-36 
to Ai 

Population count parity of (Vj) 3-93 
to (Vi) 



Scalar leading zero count 



Machine 
Instruction 

027ij0 



CAL 



Ai ZSj 



Description Page 

Leading zero count of (Sj) to Ai 3-37 



BRANCH INSTRUCTIONS 

Instructions in this category include conditional and unconditional 
branch instructions. An expression or the contents of a B register 
specify the branch address. An address is always taken to be a parcel 
address when the instruction is executed. If an expression has a 
word-address attribute, the assembler issues an error message. 
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Unconditional branch instructions 



Machine 






Instruction 


CAL 


Description 


0050J& 


J Ejk 


Jump to (Bjk) 


006 ij km 


J exp 


Jump to exp 



Page 
3-26 
3-27 



Conditional branch instructions 



Machine 
Instruction 

10 ijkm 

11 ij km 

012 ijkm 

013 ijkm 

014 ijkm 

015 ijkm 

016 ijkm 

017 ijkm 



CAL 

JAZ exp 
JAN exp 
JAP exp 
JAM exp 
JSZ exp 
JSN exp 
JSP exp 
JSM exp 



Description Page 

Branch to exp if (A0)=0 3-2 9 

Branch to exp if (A0)^0 3-29 

Branch to exp if (A0) positive 3-29 

Branch to exp if (A0) negative 3-29 

Branch to exp if (S0)=0 3-30 

Branch to exp if (S0)/0 3-30 

Branch to exp if (SO) positive 3-30 

Branch to exp if (SO) negative 3-30 



Return jump 

Machine 
Instruction 

ooiooot 

007 ijkm 



CAL 
PASS 
R exp 



Description 

Pass 

Return jump to exp; set BOO 
to (P) + 2 



Page 
3-11 
3-28 
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Normal exit 

Machine 
Instruction 

004000 



CAL 



EX 



Description 
Normal exit 



Page 
3-25 



Error exit 

Machine 
Instruction 

000000 



CAL 



ERR 



Description 
Error exit 



Page 
3-10 



MONITOR MODE INSTRUCTIONS 

Instructions described in this category are executed only when the CPU is 
in monitor mode. An attempt to execute one of these instructions when 
not in monitor mode is treated as a pass instruction. 

The instructions perform specialized functions useful to the operating 
system. 



Channel control 

Machine 
Instruction 



OOlOjfct 



OOlljfct 



CAL 



CA,Aj Ak 



CL,Aj Ak 



Description 

Set the Current Address (CA) 
register, for the channel 
indicated by (Aj), to (Ak) 
and activate the channel 

Set the channel (Aj) limit 
address to (Ak) 



Page 
3-11 



3-12 



f Privileged to monitor mode 
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Machine 
Instruction 

0012J0+ 

0012J1 



0013j0t 



CAL 

CI,Aj 

MC,AJ 



XA kj 



Description Page 

Clear Channel (kj) Interrupt 3-13 

flag 

Clear Channel (kj) Interrupt 3-13 

flag and Error flag; set device 

master-clear (output channel); 

clear device ready-held 

(input channel) 

Enter XA register with (kj) 3-14 



Set real-time clock 

Machine 
Instruction 



0014J0 



CAL 
RT Sj 



Description 

Enter RTC with (Sj) 



Page 
3-15 



Programmable clock interrupt instructions 



Machine 




Instruction 


CAL 


0014J4 


PCI Sj 


001405 


CCI 


001406 


ECI 


001407 


DC I 



Description Page 

Set program interrupt interval 3-15 

Clear clock interrupt 3-15 

Enable clock interrupts 3-15 

Disable clock interrupts 3-15 



Interprocessor interrupt instructions ' 



Machine 
Instruction 

0014jltt 



CAL 



SIPI exp 



Description 

Set interprocessor interrupt 
request of CPU exp; 0<expO 



Page 
3-15 



f Privileged to monitor mode 

ft CRAY X-MP computer systems with multiprocessors 
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Machine 
Instruction 

00 140 it ttt 



001402ttt 



CAL 



SIPI 



CIPI 



Description Page 

Set interprocessor interrupt 3-15 
request 

Clear interprocessor interrupt 3-15 



Cluster number instructions 



Machine 
Instruction 

0014j3ttt 



CAL 



CLN exp 



Description 




Paqe 


Cluster number : 


= exp where 


3-15 


0<exp<5 







Operand range error interrupt instructions 



Machine 
Instruction 

002300 



002400 



CAL 



ERI 



DRI 



Description 

Enable interrupt on address 
range error 

Disable interrupt on address 
range error 



Page 
3-21 

3-21 



Performance counterstt 



Machine 
Instruction 

0015J0 

001501 

001511 



CAL 



Description Page 

Select performance monitor 3-18 

Set maintenance read mode 3-18 

Load diagnostic checkbyte with 3-18 
SI 



f Special CAL syntax 

tt Instructions not supported by CAL at this time 

ttt CRAY X-MP computer systems with multiprocessors 
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Machine 
Instruction 

00152lt 

00153lt 

073illtt 

073i2ltf 

073i3ltt 



CAL 



Description Page 

Set maintenance write mode 1 3-18 

Set maintenance write mode 2 3-18 

Read performance counter into Si 3-67 

Increment performance counter 3-67 

Clear all maintenance modes 3-67 



f Instructions not supported by CAL at this time 
f"f* Not currently supported 
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CRAY X-MP SYSTEM CONFIGURATIONS 



The CRAY X-MP mainframe, I/O Subsystem (IOS), and associated equipment 
units are available with a number of options in a variety of system 
configurations. The options, such as the number of central processing 
units (CPUs), I/O Processors (IOPs), and channel connections, and a 
variety of memory sizes, banking arrangements, and peripheral devices, 
are used to produce several unique models. Table 4-1 shows an overview 
of all CRAY X-MP models currently available. A specification sheet is 
provided for each model later in this section; each specification sheet 
contains specific information for each of the CRAY X-MP models. 



HR-3005 4-1 



HR-3005 4-2 



Table 4-1. CRAY X-MP Computer Systems Overview 



Model 


Number of 
CPUs 


Number of 

Columns 

c 


Memory 
Size 
(MWs) 


Number of 
Banks 


Clock 
Speed 


Channel Pairs (Maximum) 




I0S Information (all totals are 


maximum configu 


ration) 




Number of 
IOPs (2 is 
minimum number) 


Buffer 
Memory 
Size (Mword) 


Disk 
Storage 

Units 


Magnetic 

Tape 
Channels 


Front-end Interfaces 
(or NSC A130 Adapters) 




6 
Mbyte/s 


100 
Mbyte/s 


1000 
Mbyte/s 


HSX - 100 
Mbyte/s 


SSD (32, 64, 128 
256. or 512 Mword) 


X-MP/14se 


1 


6 


4 


16 


xx. x ns 


2 


2 


NA 


Optional 


2 


2 (4, 8 optional) 


8 


4 


3 


Not Available 


X-MP/ 14 


1 


8 


4 


16 


8.5 ns 


4 


2 


1 


Optional 


4 


4 (8 optional) 


32 


8 




Optional 


X-MP/ 18 


1 


8 


8 


32 


8.5 ns 


4 


2 


1 


Optional 


4 


4 (8 optional) 


23 


8 




Optional 


X-MP/116 


1 


8 


16 


32 


8.5 ns 


4 


2 


1 


Optional 


4 


4 (8 optional) 


32 


8 




Optional 


X-MP/22 


2 


8 


2 


16 


8.5 ns 


4 


2 


1 


Optional 


4 


4 (8 optional) 


32 


8 




Optional 


X-MP/24 


2 


8 


4 


16 


8.5 ns 


4 


2 


1 


Optional 


4 


4 (8 optional) 


32 


8 




Optional 


X-MP/28 


2 


8 


8 


32 


8.5 ns 


4 


2 


1 


Optional 


4 


4 (8 optional) 


32 


8 




Optional 


X-MP/216 


2 


8 


16 


32 


8.5 ns 


4 


2 


1 


Optional 


4 


4 (8 optional) 

/ 


32 


8 




Optional 


X-MP/44 


4 


12 


4 


32 


8.5 ns 


4 


4 


2 


Optional 


4 


4 (8 optional) 


32 


8 




Optional 


X-MP/48 


4 


12 


8 


32 


8.5 ns 


4 


4 


2 


Optional 


4 


8 


32 


8 




Optional 


X-MP/416 


4 


12 


16 


64 


8.5 ns 


4 


4 


2 


Optional 

i 


4 


8 


32 


8 




Optional 



CRAY X-MP/14se SPECIFICATION SHEET 




Figure 4-1. CRAY X-MP/14se Computer System 
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Table 4-2. CRAY X-MP/14se Features 



CPU Features 


Functional Units Available 




(Register Usage) 


Number of CPUs 


1 


Address functional units: 


Clock speed 


xx. x ns 


Addition (A) 


Memory size 


4 Mword 


Multiplication (A) 


Number of banks 


16 


Scalar functional units: 


Number of memory 


4 (A, B 


Addition (S) 


ports 


C, I/O) 


Shift-single (S) 


Channels 


Two 100 Mbyte/ s 


Shift-double (S) 




to IOS 


Logical (S) 




Two 6 Mbyte /s 


Population, parity, and 




to IOS 


leading zero (S) 


Number of columns 


6 


Vector functional units: 


Arc 


135° 


Addition (S and V) 


Floor Space 


19.4 sq ft 


Shift (V) 




(1.8 m 2 ) 


Full vector logical (S and V) 


Weight 


2.95 tons 


2nd vector logical (S and V) 




(2676.2 kg) 


Population, parity (V) 
Floating-point functional units: 
Addition (S and V) 
Multiplication (S and V) 
Reciprocal approximation 
(S and V) 


Register Type Available: 


Quantity 


Size 


Address (A) 


8 


24 bits 


Intermediate (B) 


64 


24 bits 


Scalar (S) 


8 


64 bits 


Scalar-save (T) 


64 


64 bits 


Vector (V) 


8 


64 elements 
(64 bits per element) 


Unique Features 


• IOS resides in mainframe cabinet. 


• Unattended operation is possible; environmental monitor shuts 


system down in emergency power-off situations. 


• Installation process is simpler than with standard CRAY X-MP model. 


• Motor alternator and condenser unit in computer room. 


• Pre-installation requirements are floor cut-outs and water supply. 
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Table 4-2. CRAY X-MP/14se Features (continued) 



Special Instruction Information 


The following instructions are not available: 

Interprocessor instructions - 0014J1, 001401, 001402, 0014j"3, 
0034jk, 0036j7c, 0037jk, 026ij7, 027ij7, 072i02, 
072ij3, 073ijl, 073202, 073ij'3 


Support Equipment 


Number of Units Needed 


Power distribution unit 
Quietized motor alternator (75 KVA) 
Quietized condensing unit 
Environmental monitor (for unattended 
emergency power-off situations) 


1 
1 
1 
1 



CRAY X-MP/14se 




Peripheral Expander 

(Including Disk 

Unit and Magnetic 

Tape Unit) 



m ° 



MIOP 



<2 CRTs) 



BIOP 

(1 CRT) 



DO. 5 



BMC-5 



Printer/ 
Plotter 




Up to 3 FEIs or 
^ NSC A130 Adapters i" 1 "'' 



Customer-furnished Equipment 



DD-39 



DD-39 



Hiii 



3 39 



;IiiiS 



will 



DD-39 



Up to 4 IBM-compatible 
Tape Channels 



ijlilllj Optional equipment 
— _^_ _ 6-Mbyte/s channel 
^mhm 100-Mbyte/s channel 

t One DCU-5 is required, but priced separately. 

tt A second 100-Mbyte/s channel is needed if 
the optional BMC-5 or HSX-1 is used. 

ttt An FEI-1 box is not included. 
51 Software support for the second 6-Mbyte/s 
channel is not currently available. 



Figure 4-2. CRAY X-MP/14se Configuration (Maximum) 



HR-3005 



4-5 



RESEARCH. INC. 



Copyright® 1987 by CRAY RESEARCH, INC. 



CRAY X-MP/14 SPECIFICATION SHEET 




Figure 4-3. CRAY X-MP/14 Computer System 
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Table 4-3. CRAY X-MP/14 Features 



CPU Features 


Functional Units Available 






(Register Usage) 


Number of CPUs 


1 


Address functional units: 


Clock speed 


8.5 ns 


Addition (A) 


Memory size 


4 Mword 


Multiplication (A) 


Number of banks 


16 


Scalar functional units: 


Number of memory 


4 (A, B, 


Addition (S) 


ports 


C, I/O) 


Shift-single (S) 


Channels 


One 1000 Mbyte/s 


Shift-double (S) 




to SSD 


Logical (S) 




Up to two 100 


Population, parity, and 




Mbyte/s to 


leading zero (S) 




I OS 


Vector functional units: 




Up to four 


Addition (S and V) 




6 Mbyte/s 


Shift (V) 


Number of columns 


8 


Full vector logical (S and V) 


Arc 


180° 


2nd vector logical (S and V) 


Floor space 


25.75 sq ft 


Population, parity (V) 




(2.39 m 2 ) 


Floating-point functional units: 


Weight 


3.76 tons 


Addition (S and V) 




(3411.1 kg) 


Multiplication (S and V) 
Reciprocal approximation 
(S and V) 


Register Type Avai; 


Lable: 


Quantil 


-y 


Size 


Address (A) 




8 




24 bits 


Intermediate (B) 




64 




24 bits 


Scalar (S) 




8 




64 bits 


Scalar-save (T) 




64 




64 bits 


Vector (V) 




8 




64 elements 
(64 bits per element) 




Unique Fea 


tures 


• Can be field-upgraded to a dual-processor system 
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Table 4-3. CRAY X-MP/14 Features (continued) 



Special Instruction Information 


The following instructions are not available: 

Interprocessor instructions - 0014J1, 001401, 001402, 0014J3, 
0034J&, 0036J&, 0031jk, Q26ij7 , 027ij7, 072i02, 
072ij'3, 073ijl, 073102, 073ij3 


Support Equipment 


Number of Units Needed 


Mainframe power distribution unit 
IOS power distribution unit 
Refrigeration condensing unit 
Motor-generator sets 

SSD power distribution unit (optional) 
Maintenance micro computer unit 


1 
1 
1 
2 
1 
1 



SSD 

(64,128,256 

or 512 Mword) 




6-Mbyte/s channel 
100-Mbyte/s channel 
1000-Mbyte/s channel 
Optional equipment 





p 
















(Including Disk 
Unit and Magnetic 
Tape Unit) 




Printer/ 
Plotter 






























>1 

M ~ 
O H 

e a 

W c 

£ O 

u u 
<u a, 

<H o 

m 

3 -0 

IS u 

o 

XI s 

M S 
O 1 
S co 

X - 
1 


MIOP 

(3 CRTs) 


LSP-4 


— ► To 3 FEIs or NSC A130 Adapters 


LSP-4 


— ► To 4 FEIs or NSC A130 Adapters 








BIOP 

(1 CRT) 


DCU-5 




DD-49 


DD-49 


DD-49 


DD-49 




DCU-5 




W$> 19 


DD-49 


DD-49 






DCU-5 


DD-49 


DD-4 9 


ED- 4 9 


DB~4* 




DCU-5 


DD-49 


DD-49 


DD-4 9 


ilillll 








©SO* 

(1 CRT} 


DCtt-5 




liilli 


DD-49 


DD-4 9 


DD-49 




DCU-5 


W-4$ 


imiin 


DD-49 


DD-4$ 




DCU-5 


DD-49 


DD-49 


DD-49 


DD~49 




DCU-5 


DD-49 


DD-49 


DC-49 


DD-49 
















XlOP 

(1 CRT} 


Hill 




Customer-furnished Equipment 




BMC 5 


^^ ► 8 IBM-compatible 
^^^ Tape Channels 


" 5 


SSD-3I 
32 Mword 





Figure 4-4. CRAY X-MP/14 Configuration (Maximum) 
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CRAY X-MP/18 SPECIFICATION SHEET 




Figure 4-5. CRAY X-MP/18 Computer System 
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Table 4-4. CRAY X-MP/18 Features 



CPU Features 


Functional Units Available 






(Register Usage) 


Number of CPUs 


1 


Address functional units: 


Clock speed 


8.5 ns 


Addition (A) 


Memory size 


8 Mword 


Multiplication (A) 


Number of banks 


32 


Scalar functional units: 


Number of memory 


4 (A, B, 


Addition (S) 


ports 


C, I/O) 


Shift-single (S) 


Channels 


One 1000 Mbyte/s 


Shift-double (S) 




to SSD 


Logical (S) 




Up to two 100 


Population, parity, and 




Mbyte/s to 


leading zero (S) 




IOS 


Vector functional units: 




Up to four 


Addition (S and V) 




6 Mbyte/s 


Shift (V) 


Number of columns 


8 


Full vector logical (S and V) 


Arc 


180° 


2nd vector logical (S and V) 


Floor space 


25.75 sq ft 


Population, parity (V) 




(2.39 m 2 ) 


Floating-point functional units: 


Weight 


3.76 tons 


Addition (S and V) 




(3411.1 kg) 


Multiplication (S and V) 
Reciprocal approximation 
(S and V) 


Register Type Avail c 


ible: 


Quantit 


-Y 


Size 


Address (A) 




8 




24 bits 


Intermediate (B) 




64 




24 bits 


Scalar (S) 




8 




64 bits 


Scalar-save (T) 




64 




64 bits 


Vector (V) 




8 




64 elements 
(64 bits per element) 




Unique Feat 


:ures 


• Can be field-upgi 


-aded to a dual-processor system 
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Table 4-4. CRAY X-MP/18 Features (continued) 



Special Instruction Information 


The following instructions are not available: 

Interprocessor instructions - 0014J1, 001401, 001402, 0014J3, 
0034jfc, 0036jfc, 0037J*, 026ij7, 027ij7, 072i02, 
072ij3, 073ijl, 073102, 073ij3 


Support Equipment 


Number of Units Needed 


Mainframe power distribution unit 
IOS power distribution unit 
Refrigeration condensing unit 
Motor-generator sets 

SSD power distribution unit (optional) 
Maintenance micro computer unit 


1 
1 

1 
2 
1 
1 



SSD 

(64,128,256 

or 512 Mword) 




— 6-Mbyte/s channel 

■ 100-Mbyte/s channel 

■ 1000-Mbyte/s channel 
M Optional equipment 





Peripheral Expander 
(Including Disk 
Unit and Magnetic 
Tape Unit) 














Printer/ 
Plotter 




























n ~ 

E io 
& C 

a o 

u '£ 
<a a 
"" o 

3. "0 

H 
i 


MIOP 

(3 CRTs) 


LSP-4 


— ► To 3 FEIs or NSC A130 Adapters 


LSP-4 


— ► To 4 FEIs or NSC A130 Adapters 










BIOP 

(1 CRT) 


DCU-5 




DD-49 


DD-49 


DC-4 9 


DD-49 








DCU-5 


&D-49 


DC-49 


DD-49 


DD-49 








DCU-5 


DD-49 


DD-49 


DD-49 


DD-49 








DCU-5 


DD-49 


DD-49 


DD-49 


DD-49 








{1 CRT) 


octr-s 










DD-49 


DD-49 


DD-49 


DD-49 








DCU-5 


00-43 


iilllii 


DD-49 


DD-49 








DCU-5 


DD-49 


DD-49 


DD-49 


DD-49 








DCU-5 


DD-49 


DD-49 


DD-49 


DD-49 


















{1 CRT) 


HSX-3, 1 






Customer-furnished Equipment 


s 




BMC-S 




BMC- 5 


^^ » o IBM-compatible 
^-*" Tape Channels 


SSD-3I 
32 Mword 





Figure 4-6. CRAY X-MP/18 Configuration (Maximum) 
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CRAY X-MP/116 SPECIFICATION SHEET 




Figure 4-7. CRAY X-MP/116 Computer System 
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Table 4-5. CRAY X-MP/116 Features 



CPU Features 


Functional Units Available 






(Register Usage) 


Number of CPUs 


1 


Address functional units: 


Clock speed 


8.5 ns 


Addition (A) 


Memory size 


16 Mword 


Multiplication (A) 


Number of banks 


32 


Scalar functional units: 


Number of memory 


4 (A, B, 


Addition (S) 


ports 


C, I/O) 


Shift-single (S) 


Channels 


One 1000 Mbyte/s 


Shift-double (S) 




to SSD 


Logical (S) 




Up to two 100 


Population, parity, and 




Mbyte/s to 


leading zero (S) 




IOS 


Vector functional units: 




Up to four 


Addition (S and V) 




6 Mbyte/s 


Shift (V) 


Number of columns 


8 


Full vector logical (S and V) 


Arc 


180° 


2nd vector logical (S and V) 


Floor space 


25.75 sq ft 


Population, parity (V) 




(2.39 m 2 ) 


Floating-point functional units: 


Weight 


3.76 tons 


Addition (S and V) 




(3411.1 kg) 


Multiplication (S and V) 
Reciprocal approximation 
(S and V) 


Register Type Avai] 


Lable: 


Quant it 


-Y 


Size 


Address (A) 




8 




24 bits 


Intermediate (B) 




64 




24 bits 


Scalar (S) 




8 




64 bits 


Scalar-save (T) 




64 




64 bits 


Vector (V) 




8 




64 elements 
(64 bits per element) 


Unique Features 


• Can be field-upgraded to a dual-processor system 
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Table 4-5. CRAY X-MP/116 Features (continued) 



Special Instruction Information 


The following instructions are not available: 

Interprocessor instructions - 0014J1, 001401, 001402, 0014J3, 
0034J*, 0036J&, 0037JK, 026ij'7, 027ij7, 072i02, 
072ij3, 073ijl, 073202, 073ij3 


Support Equipment 


Number of Units Needed 


Mainframe power distribution unit 
IOS power distribution unit 
Refrigeration condensing unit 
Motor-generator sets 

SSD power distribution unit (optional) 
Maintenance micro computer unit 


1 
1 
1 
2 
1 
1 



SSD 

(64,128,256 

or 512 Mword) 




— 6-Mbyte/s channel 

■ 100-Mbyte/s channel 

■ 1000-Mbyte/s channel 
H Optional equipment 



Peripheral Expander 
(Including Disk 
Unit and Magnetic 
Tape Unit) 



(3 CRTs) 



BIOP 

(1 CRT) 



DIOP 

(1 CRT) 



XIOP 

(1 CRT) 



SSD-3I 

: 32 Mword 



Printer/ 
Plotter 



DCU-5 : 



DOJ-5 



!DCU-5 : 



:BMC-5 



To 3 FEIs or NSC A130 Adapters 
To 4 FEIs or NSC A130 Adapters 



DD-49 



DD 49 



DD-49 



DD-49 



DD-49 



DD-49 



DD-49 



! DD-49! 



i DD-49 



DD-49: 



DD-49 



DP 49 



DD-49 



DD-49 



DD-49 



DD-49 



DD-49 



DD-49 



DD-49 



; DD-49 



DD-49 



DD-49 



DD-49 



DD-49 



DD-49: 



DD-49 



iiiii 



DD-49 



DD-49 



Customer-furnished Equipment 



>* 



8 IBM-compatible 
Tape Channels 



Figure 4-8. CRAY X-MP/116 Configuration (Maximum) 
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CRAY X-MP/22 SPECIFICATION SHEET 




Figure 4-9. CRAY X-MP/22 Computer System 
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Table 4-6. CRAY X-MP/22 Features 



CPU Features 


Functional Units Available 






(Register Usage) 


Number of CPUs 


2 


Address functional units: 


Clock speed 


8.5 ns 


Addition (A) 


Memory size 


2 Mword 


Multiplication (A) 


Number of banks 


16 


Scalar functional units: 


Number of memory 


4 (A, B, 


Addition (S) 


ports 


C, I/O) 


Shift-single (S) 


Channels 


One 1000 Mbyte/s 


Shift-double (S) 




to SSD 


Logical (S) 




Up to two 100 


Population, parity, and 




Mbyte/s to 


leading zero (S) 




IOS 


Vector functional units: 




Up to four 


Addition (S and V) 




6 Mbyte/s 


Shift (V) 


Number of columns 


8 


Full vector logical (S and V) 


Arc 


180° 


2nd vector logical (S and V) 


Floor space 


25.75 sq ft 


Population, parity (V) 




(2.39 m 2 ) 


Floating-point functional units: 


Weight 


3.76 tons 


Addition (S and V) 




(3411.1 kg) 


Multiplication (S and V) 
Reciprocal approximation 
(S and V) 


Register Type Avail 


Lable: 


Quant it 


-y 


Size 


Address (A) 




8 




24 bits 


Intermediate (B) 




64 




24 bits 


Scalar (S) 




8 




64 bits 


Scalar-save (T) 




64 




64 bits 


Vector (V) 




8 




64 elements 
(64 bits per element) 
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Table 4-6. CRAY X-MP/22 Features (continued) 



Special Instruction Information 


The following instructions are specific to multi-processor systems: 
Interprocessor instructions - 0014J1, 001401, 001402, 0014J3, 
0034J&, 0036j/c, 0037jk, 026ij7, 027ij7, 072i02, 
072IJ3, 073ijl, 073i02, 073ij3 


Support Equipment 


Number of Units Needed 


Mainframe power distribution unit 
IOS power distribution unit 
Refrigeration condensing unit 
Motor-generator sets 

SSD power distribution unit (optional) 
Maintenance micro computer unit 


1 
1 
1 
2 
1 
1 



SSD 

(64,128,256 

or 512 Mword) 




— 6-Mbyte/s channel 

m 100-Mbyte/s channel 

■ 1000-Mbyte/s channel 

M Optional equipment 





Peripheral Expander 
(Including Disk 
Unit and Magnetic 
Tape Unit) 














Printer/ 
Plotter 




























u — 

O -H 

6 a 
0) c 
S O 

W 4J 

<u a, 

m o 

<u 

a x( 

03 u 

o 
■o s 

M s 
O 1 

» CD 

a - 
i 


MI OP 

(3 CRTs) 


LSP-4 


— ► To 3 FEIs or NSC A130 Adapters 


LSP-4 


— ► To 4 FEIs or NSC A130 Adapters 










BIOF 

(1 CRT) 


DCU-5 




DD-49 


DD-49 


DD-49 


DD-49 








DCU-5 


OD-49 


DD-49 


DD-49 


DD-49 








DCU-5 


DD-49 


DD-4 9 


DD-49 


DD-49 








DCU-5 


DD-49 


DD-49 


DD-49 


DD 49 








BIO* 

(1 CRT) 


DCU-5 










DD-49 


DD-49 


ED- 4 9 


DD-49 








DCU-5 


DD-49 


DD-49 


1D-49 


DD-49 








DCU-5 


DD-49 


DD-49 


DD-49 


DD-49 








DCU-5 


&B-49 


DD-49 


DD-49 


DD-49 


















XIOP 

(1 CRT) 


l 1 




Customer-furnished Equipment 


BMC-5 


^S. 


BMC- 5 


^^ — ^ 8 IBM-compatible 
^^"^ Tape Channels 


SSD-3I 
32 Mword 





Figure 4-10. CRAY X-MP/22 Configuration (Maximum) 



HR-3005 



4-21 



RESEARCH. INC. 



Copyright® 1987 by CRAY RESEARCH, INC. 



CRAY X-MP/24 SPECIFICATION SHEET 




Figure 4-11. CRAY X-MP/24 Computer System 
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Table 4-7. CRAY X-MP/24 Features 



CPU Features 


Functional Units Available 






(Register Usage) 


Number of CPUs 


2 


Address functional units: 


Clock speed 


8.5 ns 


Addition (A) 


Memory size 


4 Mword 


Multiplication (A) 


Number of banks 


16 


Scalar functional units: 


Number of memory 


4 (A, B, 


Addition (S) 


ports 


C, I/O) 


Shift-single (S) 


Channels 


One 1000 Mbyte/s 


Shift-double (S) 




to SSD 


Logical (S) 




Up to two 100 


Population/ parity, and 




Mbyte/s to 


leading zero (S) 




IOS 


Vector functional units: 




Up to four 


Addition (S and V) 




6 Mbyte/s 


Shift (V) 


Number of columns 


8 


Full vector logical (S and V) 


Arc 


180° 


2nd vector logical (S and V) 


Floor space 


25.75 sq ft 


Population, parity (V) 




(2.39 m 2 ) 


Floating-point functional units: 


Weight 


3.76 tons 


Addition (S and V) 




(3411.1 kg) 


Multiplication (S and V) 
Reciprocal approximation 
(S and V) 


Register Type Avail 


Lable: 


Quantit 


-Y 


Size 


Address (A) 




8 




24 bits 


Intermediate (B) 




64 




24 bits 


Scalar (S) 




8 




64 bits 


Scalar-save (T) 




64 




64 bits 


Vector (V) 




8 




64 elements 
(64 bits per element) 
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Table 4-7. CRAY X-MP/24 Features (continued) 



Special Instruction Information 


The following instructions are specific to multi-processor systems: 
Interprocessor instructions - 0014J1, 001401, 001402, 0014j'3, 
0034j/c, 0036jk, 0031jk, 026ij"7, 027ij7, 072i02, 
072ij3, 073ijl, 073i02, 073ij3 


Support Equipment 


Number of Units Needed 


Mainframe power distribution unit 
IOS power distribution unit 
Refrigeration condensing unit (RCU-1) 
Motor-generator sets 

SSD power distribution unit (optional) 
Maintenance micro computer unit 


1 
1 
1 
2 

1 
1 



SSD 

(64,128,256 

or 512 Mword) 




6-Mbyte/s channel 
100-Mbyte/s channel 
1000-Mbyte/s channel 
Optional equipment 





Peripheral Expander 
(Including Disk 
Unit and Magnetic 
Tape Unit) 














Printer/ 
Plotter 






























U " 
O H 

s 2 
a ° 

U -U 

<u a 

<W o 
3 T> 

n m 
n a 

O 1 
S oo 

a w 

i 

<*< 


MIOP 

(3 CRTs) 


LSP-4 


— ► To 3 FEIs or NSC A130 Adapters 


LSP-4 


— ► To 4 FEIs or NSC A130 Adapters 










BIOP 

(1 CRT) 


DCU-5 




DD-49 


DD-49 


DD-49 


DD-49 








DCU-5 


DD-49 


DD-49 


DD-49 


DD-49 








DCU-5 


DD-49 


DD-49 


DD-49 


DD-49 








DCU-5 


DD-49 


D3-49 


DD-4 9 


DD-49 








(1 CRT) 


BCU-5 










DD-49 


DD-49 


TD-4 9 


DD-49 








DCU-5 


DD-49 


DD-49 


DD-49 


DD-49 








DOT- 5 


DD-49 


DD-4 9 


DD-49 


DD-49 








DCU-5 


DD-49 


DD-49 


DD-49 


DD-49 








{1 CRT) 












HSX-li 




Customer-furnished Equipment 


\ 




BMC-b 




BMC- 5 


s^* ^ Tape Channels 


SSD-3I 
32 Mword 





Figure 4-12. CRAY X-MP/24 Configuration (Maximum) 
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Figure 4-13. CRAY X-MP/28 Computer System 
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Table 4-8. CRAY X-MP/28 Features 



CPU Features 


Functional Units Available 






(Register Usage) 


Number of CPUs 


2 


Address functional units: 


Clock speed 


8.5 ns 


Addition (A) 


Memory size 


8 Mword 


Multiplication (A) 


Number of banks 


32 


Scalar functional units: 


Number of memory 


4 (A, B, 


Addition (S) 


ports 


C, I/O) 


Shift-single (S) 


Channels 


One 1000 Mbyte/ s 


Shift-double (S) 




to SSD 


Logical (S) 




Up to two 100 


Population, parity, and 




Mbyte/ s to 


leading zero (S) 




IOS 


Vector functional units: 




Up to four 


Addition (S and V) 




6 Mbyte /s 


Shift (V) 


Number of columns 


8 


Full vector logical (S and V) 


Arc 


180° 


2nd vector logical (S and V) 


Floor space 


25.75 sq ft 


Population, parity (V) 




(2.39 m 2 ) 


Floating-point functional units: 


Weight 


3.7 6 tons 


Addition (S and V) 




(3411.1 kg) 


Multiplication (S and V) 
Reciprocal approximation 
(S and V) 


Register Type Avai] 


Lable: 


Quantit 


-y 


Size 


Address (A) 




8 




24 bits 


Intermediate (B) 




64 




24 bits 


Scalar (S) 




8 




64 bits 


Scalar-save (T) 




64 




64 bits 


Vector (V) 




8 




64 elements 
(64 bits per element) 
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Table 4-8. CRAY X-MP/28 Features (continued) 



Special Instruction Information 


The following instructions are specific to multi-processor systems: 
Interprocessor instructions - 0014J1, 001401, 001402, 0014J3, 
0034J*, 0036j/c, 0037j7c, 026ij7, 027 ijl , 072i02, 
072ij3, 073ijl, 073202, 073ij3 


Support Equipment 


Number of Units Needed 


Mainframe power distribution unit 
IOS power distribution unit 
Refrigeration condensing unit 
Motor-generator sets 

SSD power distribution unit (optional) 
Maintenance micro computer unit 


1 

1 
1 
2 

1 
1 



SSD 

(64,128,256 

or 512 Mword) 




6-Mbyte/s channel 
100-Mbyte/s channel 
1000-Mbyte/s channel 
Optional equipment 





p 
















(Including Disk 
Unit and Magnetic 
Tape Unit) 




Printer/ 
Plotter 






























O H 

e « 
<» a 
a o 

•H 
U i> 
0) Q. 

4-1 o 
1-1 
3 T) 

m u 

o 

•o * 

M E 
O 1 
* CO 

a — 

1 


MIOP 

(3 CRTs) 


LSP-4 


— ► To 3 FEIs or NSC A130 Adapters 


LSP-4 


— ► To 4 FEIs or NSC A130 Adapters 










BIOP 

(1 CRT) 


DCU-5 




DD-49 


DD-49 


DD-49 


DD-49 








DCU-5 


m>-w 


PO-49 


DD-49 


liillil 








DCU-5 


DD-49 


DD-4 9 


DD-49 


DD-49 








DCU-5 


MXZMMm 


DD-49 


DD-49 


JD-49 










DXOl? 

(1 CRT) 


iilll 










BD-49 


DD-49 


DD-49 


3D- 49 








DCU-5 


&D-4& 


DD-49 


HUMS 


DD-49 








DCV-S 


DD-49 


DD-49 


DD-49 


DD-49 








DCO-5 


BD-49 


DD-49 


DD-49 


DD-49 




















XXOfr 

(1 CRT) 


HSX-H 




Customer-furnished Equipment 


Htti 


\ . „ ,„,. 


EMC- 5 


^ 


Tape Channels 


SSD-3I 
32 Mword 



Figure 4-14. CRAY X-MP/28 Configuration (Maximum) 
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Figure 4-15. CRAY X-MP/216 Computer System 
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Table 4-9. CRAY X-MP/216 Features 



CPU Features 


Functional Units Available 






(Register Usage) 


Number of CPUs 


2 


Address functional units: 


Clock speed 


8.5 ns 


Addition (A) 


Memory size 


16 Mword 


Multiplication (A) 


Number of banks 


32 


Scalar functional units: 


Number of memory 


4 (A, B, 


Addition (S) 


ports 


C, I/O) 


Shift-single (S) 


Channels 


One 1000 Mbyte/ s 


Shift-double (S) 




to SSD 


Logical (S) 




Up to two 100 


Population, parity, and 




Mbyte/ s to 


leading zero (S) 




IOS 


Vector functional units: 




Up to four 


Addition (S and V) 




6 Mbyte/s 


Shift (V) 


Number of columns 


8 


Full vector logical (S and V) 


Arc 


180° 


2nd vector logical (S and V) 


Floor space 


25.75 sq ft 


Population, parity (V) 




(2.39 m 2 ) 


Floating-point functional units: 


Weight 


3.76 tons 


Addition (S and V) 




(3411.1 kg) 


Multiplication (S and V) 
Reciprocal approximation 
(S and V) 


Register Type Avai] 


Lable: 


Quantit 


-Y 


Size 


Address (A) 




8 




24 bits 


Intermediate (B) 




64 




24 bits 


Scalar (S) 




8 




64 bits 


Scalar-save (T) 




64 




64 bits 


Vector (V) 




8 




64 elements 
(64 bits per element) 
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Table 4-9. CRAY X-MP/216 Features (continued) 



Special Instruction Information 


The following instructions are specific to multi-processor systems: 
Interprocessor instructions - 0014j"l, 001401, 001402, 0014J3, 
0034J&, 0036JA, 0037J&, 0262J7, 027ij7, 072i02, 
072IJ3, 0731J1, 073102, 073ij'3 


Support Equipment 


Number of Units Needed 


Mainframe power distribution unit 
IOS power distribution unit 
Refrigeration condensing unit 
Motor-generator sets 

SSD power distribution unit (optional) 
Maintenance micro computer unit 


1 

1 
1 
2 
1 
1 



SSD 

(64,128,256 

or 512 Mword) 




— 6 -Mbyte /s channel 

■" 100-Mbyte/s channel 

■ 1000-Mbyte/s channel 

H Optional equipment 



















(Including Disk 
Unit and Magnetic 
Tape Unit) 




Printer/ 
Plotter 




























>1 

u _ 

8 H 
I S 

u « 
P a 

m Y, 

u 1 

1 » 

1 

<3< 


MIOP 

(3 CRTs) 


LSP-4 


— ► To 3 FEIs or NSC A130 Adapters 


LSP-4 


— ► To 4 FEIs or NSC A130 Adapters 










BIOP 

(1 CRT) 


DCU-5 




DD-49 


DD-49 


DE-49 


DD-49 








DCU-5 


DD-4& 


llllllf 


liiliii 


DD-49 








DCU-5 


DD~4$ 


DD-49 


DD-49 


DD-49 








DCU-5 


SD-49 


DD-49 


DD-49 


DD-49 














DIOP 

(1 CRT) 


3CU-5 




BD-49 


l§|f§||§ 


DD-49 


DD-49 








DCU-5 


ED-49 


DD-49 


DD-49 


DD-49 








DCU-5 


DD-49 


DD-49 


DD-49 


DD-49 








DCU-5 


BB-49 


DD-49 


DD-49 


DD-49 


















^ 




XIOP 

(1 CRT) 


HSX-1 1 


^4 Customer-furnished Equipment 


BMC-5 


^ ^. 8 IBM-compatible 

Tape Channels 


BMC- 5 


SSD-3I 
32 Mword 



Figure 4-16. CRAY X-MP/216 Configuration (Maximum) 
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Figure 4-17. CRAY X-MP/44 Computer System 
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Table 4-10. CRAY X-MP/44 Features 



CPU Features 




Functional Units Available 








(Register Usage) 


Number of CPUs 


4 




Address functional units: 


Clock speed 


8.5 ns 




Addition (A) 


Memory size 


4 Mword 




Multiplication (A) 


Number of banks 


32 




Scalar functional units: 


Number of memory 


4 (A, B, 




Addition (S) 


ports 


C, I/O) 




Shift-single (S) 


Channels 


Two 1000 Mbyte/ s 


Shift-double (S) 




to SSD 




Logical (S) 




Up to four IOC 




Population, parity, and 




Mbyte/ s to 




leading zero (S) 




IOS 




Vector functional units: 




Up to four 




Addition (S and V) 




6 Mbyte /s 




Shift (V) 


Number of columns 


12 




Full vector logical (S and V) 


Arc 


270° 




2nd vector logical (S and V) 


Floor space 


38.5 sq ft 




Population, parity (V) 




(3.57 m 2 ) 




Floating-point functional units: 


Weight 


5.65 tons 




Addition (S and V) 




(5125.5 kg) 




Multiplication (S and V) 
Reciprocal approximation 
(S and V) 


Register Type Avai] 


Lable: 


Quantit 


-Y 


Size 


Address (A) 






8 




24 bits 


Intermediate (B) 






64 




24 bits 


Scalar (S) 






8 




64 bits 


Scalar-save (T) 






64 




64 bits 


Vector (V) 






8 




64 elements 
(64 bits per element) 
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Table 4-10. CRAY X-MP/44 Features (continued) 



Special Instruction Information 


The following instructions are specific to multi-processor systems: 
Interprocessor instructions - 0014J1, 001401, 001402, 0014J3, 
0034J&, 0036J&, 0037J&, 026ij7, 0272J7, 072i02, 
0722J3, 073IJ1, 073102, 073ij*3 


Support Equipment 


Number of Units Needed 


Mainframe power distribution unit 
IOS power distribution unit 
Refrigeration condensing unit 
Auxilliary refrigeration condensing units 

(with SSD - 2 units needed) 
Motor-generator sets 

SSD power distribution unit (optional) 
Maintenance micro computer unit 


1 

1 
1 
1 

3 
1 

1 



SSD 

(64,128,256 
or 512 Mword) 




IOS 

6-Mbyte/s channel 
100-Mbyte/s channel 
1000-Mbyte/s channel 
Optional equipment 



Four 100-Mbyte/s channels are standard; 
software to support the MIOP and DIOP 
channel connection to Central Memory 
is not currently available. 



Peripheral Expander 
(Including Disk 
Unit and Magnetic 
Tape Unit) 



BIOF 

(1 CRT) 



DIOP 

{1 CRT) 



XIO* 

(1 CRT) 



SSD-3I 
32 Mword 



Printer/ 
Plotter 



To 3 FEIs 
To 4 FEIs 



NSC A130 Adapters 
NSC A130 Adapters 



a*j-5 ^ 



Customer-furnished Equipment I 



8 IBM-compatible 
Tape Channels 



Figure 4-18. CRAY X-MP/44 Configuration (Maximum) 
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Figure 4-19. CRAY X-MP/48 Computer System 
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Table 4-11. CRAY X-MP/48 Features 



CPU Features 


Functional Units Available 






(Register Usage) 


Number of CPUs 


4 


Address functional units: 


Clock speed 


8.5 ns 


Addition (A) 


Memory size 


8 Mword 


Multiplication (A) 


Number of banks 


32 


Scalar functional units: 


Number of memory 


4 (A, B, 


Addition (S) 


ports 


C, I/O) 


Shift-single (S) 


Channels 


Two 1000 Mbyte /s 


Shift-double (S) 




to SSD 


Logical (S) 




Up to four 100 


Population, parity, and 




Mbyte /s to 


leading zero (S) 




IOS 


Vector functional units: 




Up to four 


Addition (S and V) 




6 Mbyte /s 


Shift (V) 


Number of columns 


12 


Full vector logical (S and V) 


Arc 


270° 


2nd vector logical (S and V) 


Floor space 


38.5 sq ft 


Population, parity (V) 




(3.57 m 2 ) 


Floating-point functional units: 


Weight 


5.65 tons 


Addition (S and V) 




(5125.5 kg) 


Multiplication (S and V) 
Reciprocal approximation 
(S and V) 


Register Type Avai] 


Lable: 


Quantil 


-y 


Size 


Address (A) 




8 




24 bits 


Intermediate (B) 




64 




24 bits 


Scalar (S) 




8 




64 bits 


Scalar-save (T) 




64 




64 bits 


Vector (V) 




8 




64 elements 
(64 bits per element) 




Unique Feal 


tures 


• 8-Mword Buffer I 


Memory is standard. 
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Table 4-11. CRAY X-MP/48 Features (continued) 



Special Instruction Information 


The following instructions are specific to multi-processor systems: 
Interprocessor instructions - 0014J1, 001401, 001402, 0014J3, 
0034J&, 0036jk, 0037jk, 026ij7, 027ij'7, 072i02, 
072ij'3, 073ijl, 073i02, 073ij3 


Support Equipment 


Number of Units Needed 


Mainframe power distribution unit 
IOS power distribution unit 
Refrigeration condensing unit 
Auxilliary refrigeration condensing units 

(with SSD - 2 units needed) 
Motor-generator sets 

SSD power distribution unit (optional) 
Maintenance micro computer unit 


1 
1 
1 
1 

3 
1 
1 



SSD 
(64,128,256 
or 512 Mword) 




IOS ■, 

6-Mbyte/s channel 
100-Mbyte/s channel 
1000-Mbyte/8 channel 



_J Optional equipment 



t Four 100-Mbyte/s channels are standard; 
software to support the MIOP and DIOP 
channel connection to Central Memory 
is not currently available. 





Peripheral Expander 

(Including Disk 

Unit and Magnetic 

Tape Unit) 














Printer/ 
Plotter 






























>. 
0) 2 

& 0. 

JJ o 

o a 
2 2 


MIOP 

(3 CRTs) 


LSP-4 


— ► To 3 FEIs or NSC A130 Adapters 


LSP-4 


— ► To 4 FEIs or NSC A130 Adapters 










BIOP 

(1 CRT) 


DOT- 5 




DD-49 


DD-4 9 


DB-4S 


DD-49 








DOT- 5 


DD-4S 


DD-49 


DD-49 


DTJ-49 








DCU-5 


DD-49 


DD-49 


33-49 


DD-49 








DOT- 5 


DD-49 


DD-49 


DD-49 


DD-49 








DIOP 

(1 CRT) 


DCU-5 










DD-49 


DD-49 


DD-49 


DD-49 








Di-'J-i 


OD-49 


BD-49 


BD-49 


DB-49 








DCU-5 


DD-49 


DD-49 


DD-45- 


DD-49 








DCU-5 


DD-49 


DD-49 


DD-49 


DD-49 








XIOP 

0. CRTS 




■■■ 
-*- 








asx-i' 


^ Customer-furnished Equipment | 


BMC-S 


^ — ^- 8 IBM-compatible 
Tape Channels 


BMC-S 


SSD- 31 
3?. Mwra 



Figure 4-20. CRAY X-MP/48 Configuration (Maximum) 
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Figure 4-21. CRAY X-MP/416 Computer System 
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Table 4-11. CRAY X-MP/416 Features 



CPU Features 


Functional Units Available 






(Register Usage) 


Number of CPUs 


4 


Address functional units: 


Clock speed 


8.5 ns 


Addition (A) 


Memory size 


16 Mword 


Multiplication (A) 


Number of banks 


64 


Scalar functional units: 


Number of memory 


4 (A, B, 


Addition (S) 


ports 


C, I/O) 


Shift-single (S) 


Channels 


Two 1000 Mbyte/ s 


Shift-double (S) 




to SSD 


Logical (S) 




Up to four 100 


Population, parity, and 




Mbyte /s to 


leading zero (S) 




IOS 


Vector functional units: 




Up to four 


Addition (S and V) 




6 Mbyte/s 


Shift (V) 


Number of columns 


12 


Full vector logical (S and V) 


Arc 


270° 


2nd vector logical (S and V) 


Floor space 


38.5 sq ft 


Population, parity (V) 




(3.57 m 2 ) 


Floating-point functional units: 


Weight 


5.65 tons 


Addition (S and V) 




(5125.5 kg) 


Multiplication (S and V) 
Reciprocal approximation 
(S and V) 


Register Type Avai] 


Lable: 


Quant it 


-y 


Size 


Address (A) 




8 




24 bits 


Intermediate (B) 




64 




24 bits 


Scalar (S) 




8 




64 bits 


Scalar-save (T) 




64 




64 bits 


Vector (V) 




8 




64 elements 
(64 bits per element) 




Unique Feat 


:ures 


• 8-Mword Buffer 1« 


lemory is standard. 
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Table 4-11. CRAY X-MP/416 Features (continued) 



Special Instruction Information 


The following instructions are specific to multi-processor systems: 
Interprocessor instructions - 0014J1, 001401, 001402, 0014j'3, 
0034jfc, 0036j/c, 0Q37jk, 026ij7, 027ij7, 072i02, 
072ij"3, 073ijl, 073i02, 073ij3 


Support Equipment 


Number of Units Needed 


Mainframe power distribution unit 
IOS power distribution unit 
Refrigeration condensing unit 
Auxilliary refrigeration condensing units 

(with SSD - 2 units needed) 
Motor-generator sets 

SSD power distribution unit (optional) 
Maintenance micro computer unit 


1 
1 
1 
1 

3 

1 
1 



SSD 
(64,128,256 
or 512 Mword) 




— 6-Mbyte/s channel 

" 100-Mbyte/s channel 

* 1000-Mbyte/s channel 

H Optional equipment 



Four 100-Mbyte/s channels are standard; 
software to support the MIOP and DIOP 
channel connection to Central Memory 
is not currently available. 



Peripheral Expander 

{Including Disk 

Unit and Magnetic 

Tape Unit) 



BIOP 

(1 CRT) 



DIOP 

(1 CRT) 



XIOP 

[1 CRT) 



SSD- 31 
32 Mword 



Printer/ 
Plotter 



To 3 FEIs or NSC A130 Adapters 
To 4 FEIs or NSC A130 Adapters 



Customer-furnished Equipment I 



>* 



8 IBM-compatible 
Tape Channels 



Figure 4-22. CRAY X-MP/416 Configuration (Maximum) 
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GLOSSARY 



A 

A register - Address register 

B 

B register - Intermediate Address register 

BDM - Bidirectional Memory Mode flag 

BIOP - Buffer I/O Processor 

BMC - Block multiplexer controller 

C 

CA - Current Address register 

CAL - Cray Assembly Language 

CCI - Clear clock interrupt 

CE - Channel Error flag 

CI - Channel Interrupt flag 

CIP - Current Instruction Parcel 

CIPI - Clear interprocessor interrupt 

CL - Channel Limit register 

CLN - Cluster Number register (Exchange Package) 

CMR - Complete memory references 

CP - Clock Period 

CPU - Central processing units 

CRI - Cray Research, Inc. 

CSB - Read Address register (Exchange Package) 

HR-3005 Glossary-1 



D 

DBA - Data Base Address register (Exchange Package) 

DBM - Disable bidirectional memory transfers 

PCI - Disable clock interrupts 

DCU - Disk controller unit 

DFI - Disable floating-point interrupt 

DIOP - Disk I/O Processor 

PL - Deadlock flag 

DLA - Pata Limit Address register (Exchange Package) 

DMA - Pirect Memory Address 

PR I - Pisable interrupt on range error interrupt 

PSU - Pisk Storage Unit 

E 

E - Error type (Exchange Package) 

EAM - Enhanced Addressing Mode (Exchange Package) 

EBM - Enable bidirectional memory transfers 

ECI - Enable clock interrupts 

EEX - Error Exit flag 

EFI - Enable floating-point interrupt 

ESVL - Enable Second Vector Logical (Exchange Package) 

EX - Normal exit 

F 

F - Flag register (Exchange Package) 

F - Floating-point operation (symbolic instructions) 

FEI - Front-end interface 
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FOL-3 - Fiber-optic link (3 Mbyte/s) 
FPE - Floating-point Error flag 
FPS - Floating-point Error Status flag 
FWA - First Word Address 

H 

H - Half-precision floating-point operation (symbolic instructions) 

HSX-1 - High-speed External Channel 

I 

I - Reciprocal iteration (symbolic instructions) 

IBA - Instruction Base Address register (Exchange Package) 

I CM - Correctable Memory Error Mode flag 

ICP - Interrupt From Internal CPU flag 

IFP - Floating-point Error Mode flag 

I LA - Instruction Limit Address register (Exchange Package) 

IMM - Interrupt Monitor Mode flag 

IQI - I/O Interrupt flag 

I OP - I/O Processor 

IOR - Operand Range Error Mode flag 

IPS - I/O Subsystem 

IUM - Uncorrectable Memory Error Mode flag 

J 

JAM - acronym for a series of branch instruction 

JAN - acronym for a series of branch instruction 

JAP - acronym for a series of branch instruction 
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JAZ - acronym for a series of branch instruction 
JR - acronym for a series of branch instruction 
JSM - acronym for a series of branch instruction 
JSN - acronym for a series of branch instruction 
JSP - acronym for a series of branch instruction 
JSZ - acronym for a series of branch instruction 

L 

LIP - Last Instruction Parcel 

M 

M - Mode register (Exchange Package) 

MC - Master Clear 

MCU - MCU Interrupt flag 

MCU - Maintenance control unit 

ME - Memory Error flag 

MIOP - Master I/O Processor 

MM - Monitor Mode flag 

N 

NEX - Normal Exit flag 

NIP - Next Instruction Parcel 



ORE - Operand Range Error flag 
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p 

P - Population count (symbolic instructions) 

P register - Program Address register (Exchange Package) 

PCI - Programmable Clock Interrupt flag 

PDU - Power distribution unit 

PN - Processor number (Exchange Package) 

PRE - Program Range Error flag 

PS - Program State register (Exchange Package) 

Q 

Q - Parity count (symbolic instructions) 

R 

R - Read mode (Exchange Package) 

R - Rounded floating-point operation (symbolic instructions) 

RT - Real-time clock (symbolic instructions) 

RTC - Real-time clock 

S 

S - Syndrome bits (Exchange Package) 

S register - Scalar register 

SB - Shared Address register 

SB - Sign Bit (symbolic instructions) 

SEI - Selected for External Interrupts flag 

SIPI - Set Interprocessor Interrupt 

SM - Semaphore register 

SSD - Solid-State storage device 

ST - Shared Scalar register 
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T 

T register - Scalar-save register 

V 

VL - Vector Length 

VM - Vector Mask 

VNU - Vector Not Used (Exchange Package) 

W 

WS - Waiting for Semaphore flag 

X 

XA - Exchange Address register (Exchange Package) 
XIOP - Auxiliary I/O Processor 

Z 

Z - Leading-zero count (symbolic instructions) 
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INDEX 



INDEX 



l-Parcel instruction format 

with combined j and k fields, 3-3 

with discrete j and k fields, 3-2 
100-Mbyte/s channel, 1-4 
1000-Mbyte/s channel, 1-6, 4-2 
16-bit instruction, 3-1 
2-Parcel instruction format 

with combined i, j, k, and m 

fields, 3-5 

with combined j, k, and m 

fields, 3-3 
6-Mbyte/s channels, 1-4, 
22-bit immediate constant, 3-3 
24-bit immediate constant, 3-110 
32-bit instruction, 3-1 
64-bit integer arithmetic, 3-110 



A registers, see Address registers 

Active Exchange Package, 2-9 

Addition algorithm, 2-23 

Addition, floating-point, 2-23 

Address Add functional unit, 2-5, 3-38, 3-39 

Address functional units, 2-5 

Address Multiply functional unit, 2-5, 3-40 

Address processing, 2-1 

Address registers, 2-4, 3-102, 3-104 

Algorithm 

addition, 2-23 

derivation of division, 2-25 

division, 2-24 

multiplication, 2-23 
AND function, 2-29 
Arithmetic instructions, 3-2 
Arithmetic operations 2-15 
Auxiliary I/O processor (XIOP), 1-4 



B registers, see Intermediate registers 

Beginning address registers, 2-30 

Bank phasing, 2-30 

Bidirectional Memory 
mode flag, 2-11 
mode, 3-22 
transfers, 3-107 

Binary machine code, 3-1 

Bit count instructions, 3-100, 3-118 
scalar leading zero count, 3-119 
scalar population count, 3-119 
scalar population count parity, 3-119 
vector population count, 3-119 



Branch instructions, 3-1, 3-119 

conditional, 3-120 

error exit, 3-121 

normal exit, 3-121 

return jump, 3-120 

unconditional, 3-120 
Buffer I/O processor (BIOP), 1-4 
Buffers, instruction, 2-8 



CA register, see Current Address register 
Central Memory, 2-30 

banks, 4-2 

memory ports, number of, see CRAY X-MP 

(model specifications) 

size, 4-2 
Central Processing Unit 

computation section characteristics, 2- 

control and data pr ths, 2-2 

input/output section, 2-31 

instruction format, 3-1 

instructions, 3-1 

overview, 3-1 

shared resources, 2-15 

speed, 4-2 
Channel 

100-Mbyte/s, 1-4, 4-2 

1000-Mbyte/s, 1-6, 4-2 

6-Mbyte/s, 1-4, 4-2 

control, 3-121 

number, 3-41 

types, 4-2 
Channel Limit register (CL), 3-11, 3-12 
Characteristics of system, 1-1 
Check bit memory storage, 3-18 
CIP register, see Current Instruction 

Parcel register 
CL register, See Channel Limit register 
Clear clock interrupt (CCI), instruction, 

3-16 
CLN register, see Cluster Number register 
Clock 

programmable, 2-3 

real-time, 2-15 
Clock period, 4-2 
Cluster number register (CLN), 2-14, 3-16, 

3-123 
CMR, 3-22 

Communication, inter-CPU, 2-15 
Composite word, 3-51 
Compressed index, 3-96 
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Computation section, 2-1 

Condensing units, 1-7 

Conditional branch instructions, 3-120 

Configurations of system, see CRAY X-MP 

(model specifications) 
Control and data paths of CPU, 2-2 
Control, inter-CPU, 2-15 
Conventions, notational, 1-10 
Correctable Memory Error Mode flag, 2-11 
CP, see clock period 
CPU, see Central Processing Unit 
CPU operating registers 
A registers, 2-4 
address registers, 2-4 
B registers, 2-4 
S registers, 2-4 
scalar registers, 2-4 
T registers, 2-4 
V registers, 2-4 
Vector registers, 2-4 
CRAY X-MP (model specifications), 4-1 
/14se computer system, 4-3 
CPU features, 4-4 
Functional units, 4-4 
Maximum configuration, 4-5 
Register types, 4-4 
Special instructions, 4-5 
Support equipment, 4-5 
Unique features, 4-5 
/14 computer system, 4-7 
CPU features, 4-8 
Functional units, 4-8 
Maximum configuration, 4-9 
Register types, 4-8 
Special instructions, 4-9 
Support equipment, 4-9 
Unique features, 4-8 
/18 computer system, 4-11 
CPU features, 4-12 
Functional units, 4-12 
Maximum configuration, 4-13 
Register types, 4-12 
Special instructions, 4-13 
Support equipment, 4-13 
Unique features, 4-12 
/116 computer system, 4-15 
CPU features, 4-16 
Functional units, 4-16 
Maximum configuration, 4-17 
Register types, 4-16 
Special instructions, 4-17 
Support equipment, 4-17 
Unique features, 4-16 
/22 computer system, 4-19 
CPU features, 4-20 
Functional units, 4-20 
Maximum configuration, 4-21 
Register types, 4-20 
Special instructions, 4-21 
Support equipment, 4-21 
/24 computer system, 4-23 
CPU features, 4-24 
Functional units, 4-24 



CRAY X-MP (model specifications) (continued) 

Maximum configuration, 4-2 5 

Register types, 4-24 

Special instructions, 4-25 

Support equipment, 4-25 
/28 computer system, 4-27 

CPU features, 4-28 

Functional units, 4-28 

Maximum configuration, 4-29 

Register types, 4-28 

Special instructions, 4-29 

Support equipment, 4-29 
/216 computer system, 4-31 

CPU features, 4-32 

Functional units, 4-32 

Maximum configuration, 4-33 

Register types, 4-32 

Special instructions 4-33 

Support equipment, 4-33 
/44 computer system, 4-35 

CPU features, 4-36 

Functional units, 4-36 

Maximum configuration, 4-37 

Register types, 4-36 

Special instructions, 4-37 

Support equipment, 4-37 
/48 computer system, 4-39 

CPU features, 4-40 

Functional units, 4-40 

Maximum configuration, 4-41 

Register types, 4-40 

Special instructions, 4-41 

Support equipment, 4-41 

Unique feature, 4-40 
/416 computer system, 4-43 

CPU features, 4-44 

Functional units, 4-44 

Maximum configuration, 4-45 

Register types, 4-44 

Special instructions, 4-45 

Support equipment, 4-45 

Unique feature, 4-44 
CSB - read address, 2-10 

Current Address register (CA), 3-11, 3-41 
Current Instruction Parcel register (CIP), 
2-9, 3-23 



Data Base Address register (DBA), 2-14 
Data formats 

integer, 2-16 

floating-point, 2-17 
Data Limit Address register (DLA), 2-14 
DBA register, see Data Base Address register 
DBM, 3-22 

Decimal equvialents, 2-17 

Derivation of the division algorithm, 2-25 
DFI, 3-21 

Disable floating-point interrupt, 3-21 
Disk control unit, 1-5 
Disk I/O processor (DIOP), 1-4 
Disk storage units, 1-5 
Division algorithm, 2-24 
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DL flag, 3-23 

DLA register, see Data Limit Address 

register 
Double-precision numbers, 2-22 
Double-shift instructions, 3-2 
DRI, 3-21 



E - error type, 2-10 

EBM, 3-22 

EFI, 3-21 

Enable floating-point interrupt, 3-21 

ERI, 3-21 

Error condition, 3-10 

Error detection and correction, 3-18 

Error Exit flag, 3-10 

Error exit, 3-121 

Error flag, 3-13, 3-41 

Exchange Address (XA) register, 2-13, 3-10, 

3-25 
Exchange mechanism, 2-9 
Exchange Package, 2-9, 3-10, 3-23 

active, 2-9 

contents, 2-10 

enable Second Vector Logical, 2-12 

management, 2-12 

memory error data, 2-10 

processor number, 2-10 

vector not used (VNU), 2-12 
Exchange Package registers 

A registers, 2-15 

Cluster Number register, 2-14 

Exchange Address register, 2-13 

Flag register, 2-12 

Mode register, 2-11 

Program Address register, 2-10 

Program State register, 2-14 

S registers, 2-15 
Exchange sequence, 2-9, 3-10, 3-25 
Exclusive NOR function, 2-30 
Exclusive OR function, 2-30 
Exponent matrix for floating-point multiply 

unit, 2-20 
External Interrupts flag, 2-11 



F register, see Flag register 

Flag register, Exchange Package, 2-12, 3-10 

3-16, 3-25 
Flags 

Bidirectional Memory Mode, 2-11 

Correctable Memory Error Mode, 2-11 

External Interrupts, 2-11 

Floating-point Error Mode, 2-13 

Monitor Mode, 2-12 

Operand Range Error Mode, 2-11 

Operand Range Error, 2-11 

Program Range Error, 2-13 

Uncorrectable Memory Error Mode, 2-12 
Floating-point 

Add functional unit, 2-7, 3-59, 3-90 

add functional unit range error, 2-19 

addition, 2-23, 3-111 



Floating-point (continued) 

arithmetic, 2-17, 3-111, 3-112, 3-113 

constant instructions, 3-2 

data format, 2-17 

difference, 3-59, 3-89 

Error Mode flag, 2-12 

exponent matrix, 2-20 

functional units, 2-7 

Interrupt flag, 3-21 

multiplication, 3-112 

Multiply functional unit, 2-8, 3-61, 
3-87 

multiply functional unit out-of-range 
conditions, 2-19 

normalized numbers, 2-18 

operations, 3-98 

product half-precision rounded of, 3-61 

products half-precision rounded, 3-87 

products, 3-87 

quantity, 3-59 

range errors, 2-19 

range overflow, 2-19 

reciprocal approximation functional 
unit range error, 2-22 

subtraction, 2-23 
Floating-point arithmetic, 2-17 

exponent range, 2-17 

underflow, 2-17 
Functional units, 2-4 

address, 2-5 

Address Add, 2-5 

Address Multiply, 2-5 

Floating-point, 2-7 

Floating-point Add, 2-7 

Floating-point Multiply, 2-8 

Full Vector Logical, 2-7 

Reciprocal Approximation, 2-8 

scalar, 2-5 

Scalar Add, 2-6 

Scalar Logical, 2-6 

Scalar Population/Parity/Leading Zero, 
2-6 

Scalar Shift, 2-6 

Second Vector Logical, 2-7 

vector, 2-6 

Vector Add, 2-7 

Vector Population/Parity, 2-7 

Vector Shift, 2-7 

vector reservation, 2-5 
Functions 

AND, 3-114 

EXCLUSIVE OR, 3-114 

INCLUSIVE OR, 3-114 
Functional instruction summary, 3-102 
Functional units, 3-98 



g field, 3-1 

General instruction form, 3-1 



h field, 3-1 
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i field, 3-1 

ICP flag, 3-16 

I/O channels, 4-2 

I/O processors, types of, 1-4 

IBA register, see Instruction Base Address 

register 

Inclusive OR function, 2-29 

Instruction 

32-bit, 3-1 

arithmetic, 3-2 

bit count, 3-100, 3-118 

scalar leading zero count, 3-119 

scalar population count, 3-119 

scalar population count parity, 3-119 

vector population count, 3-119 
branch, 3-1, 3-119 

conditional, 3-120 

error exit, 3-121 

normal exit, 3-121 

return jump, 3-120 

unconditional, 3-120 
buffers, 2-8, 3-10, 3-25 
clear clock interrupt, 3-16 
cluster number, 3-120 
conditional branch, 3-120 
descriptions, 3-9 
double shift, 3-2 
functional summary, 3-102 
general form, 3-1 
JAM, 3-29 
JAP, 3-30 
JSM, 3-30 
JSP, 3-30 
monitor, 3-121 

channel control, 3-121 

cluster number, 3-123 

interprocessor interrupt, 3-122 

operand range error interrupt, 3-123 

performance counters, 3-123 

programmable clock interrupt, 3-122 

set real-time clock, 3-122 
shift, 3-100, 3-117 
summary, 3-98 
syntax, 3-1 

format, 3-1 

monitor mode, 3-9 

special register values, 3-6 

symbolic notation, 3-6 
types, 3-1 
vector, 3-19 

merge, 3-23 
Instruction Base Address register, 2-11 
Instruction buffers, 2-8, 3-10, 3-25 
Instruction format 

1-Parcel with combined j and k fields, 

3-3 
1-Parcel with discrete j and k fields, 

3-2 
2-Parcel with combined i, j, k, and m 

fields, 3-5 
2 -Parcel with combined j, k, and m 

fields, 3-3 



Instruction Limit Address register (ILA), 

2-11 
Instruction issue, 2-8 
Instruction parcel, 2-8 
Instructions, general form for, 3-1 
Integer arithmetic, 2-16, 3-100, 3-109, 

3-110 
Integer data formats, 2-16 
Inter-CPU communication and control, 2-15 
Interfaces, 1-3 
Inter-register transfers, 3-101, 3-104 

A registers, 3-104 

S registers, 3-105 

semaphore registers, 3-106 

V registers, 3-106 

Vector Length register, 3-106 

Vector Mask register, 3-106 
Intermediate registers, 2-3, 3-42, 3-43 
Internal CPU interrupt request, 3-15, 3-16 
Interprocessor interrupt 

instructions, 3-122 

requests, 3-15 
Interrupt Countdown counter (ICD), 3-16 
Interrupt flag, 3-13 

Interrupt Interval register (II), 3-16 
Issue, 3-8 



j field, 3-1 

JAM instructions, 3-29 

JAP instructions, 3-29 

JSM instructions, 3-30 

JSP instructions, 3-30 



k field, 3-1 



Loads, 3-108 
Logical 

AND function, 2-29 
differences, 3-50, 3-115 
exclusive NOR function, 2-30 
exclusive OR function, 2-29 
inclusive OR function, 2-30 
operations, 3-2, 3-99, 3-101, 3-114 

differences, 3-115 

equivalence, 3-116 

merge, 3-117 

products, 3-49, 3-50, 3-114 

sums, 3-51, 3-115 

vector mask, 3-116 
Lower Instruction Parcel register (LIP), 2-9 



m field, 3-1 

M register, see Mode register 

Mask length, 3-46, 3-47 

Mass storage, 1-5 

Master Clear, 3-13 

Master I/O processor (MIOP), 1-4 

Memory, see Central Memory 
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Memory error data fields, 2-10 

Memory 

references, 3-107 

completion, 3-22 
transfers, 3-107 

bidirectional, 3-101, 3-107 
loads, 3-108 
references, 3-107 
stores, 3-107 

Merge, 3-11 

Mode register (M), 2-11, 3-21 

Monitor instructions, 3-121 
channel control, 3-121 
cluster number, 3-121 
interprocessor interrupt, 3-122 
operand range error interrupt, 3-123 
performance counters, 3-123 
programmable clock interrupt, 3-122 
set real-time clock, 3-122 

Monitor mode, 3-10, 3-25 
flag, 2-12 
instructions, 3-9 
operations, 3-100 

Monitor program, 3-14 

Motor-generator units, 1-9 

Multiplication algorithm, 2-, 3 



Newton's method, 2-24 

Next Instruction Parcel register (NIP), 

2-9, 3-23 
Normal Exit flag, 3-25 
Normal exit, 3-121 

Normalized floating-point numbers, 2-18 
Notation conventions, 1-10 



Operand 

range error interrupt instructions, 

3-122 
Range Error flag, 2-13, 3-21 
Range Error Mode flag, 2-11 
Operating registers, see CPU operating 

registers 
Organization of system, 2-1 



P register, see Program Address register 

Parcel address, 3-26, 3-27, 3-28 

Parcel-address attribute, 3-72 

Parcels, 3-1 

Performance counters, 3-18, 3-123 

Physical dimensions of system, see CRAY X-MP 

(model specifications) 
PN, see Processor number 
Population count 

scalar, 3-119 

scalar parity, 3-119 

vector, 3-119 
Power distribution units, 1-8 
Processor Number (PN), 2-10 



Program 

Address register (P), 2-10 

instructions, 3-23, 3-26, 3-27, 3-2£ 
3-29 
branches and exits, 3-100 
range error, 3-13 
Range Error flag, 2-13 
State register (PS), 2-14 
Programmable clock, 2-3 

Programmable clock interrupt instructions, 
3-122 



R - read mode, 2-10 

Read address, 2-10 

Read mode, 2-10 

Ready flag, 3-13 

Real-time clock, 2-15, 3-15, 

Real-time clock interrupt request, 3-16 

Real-time Clock register (RTC), 2-15, 3-67 
Reciprocal Approximation functional unit, 

2-8, 3-113 
Reciprocal Approximation functional unit 

iterations, 2-27, 3-113 
Register entry instructions 

A registers, 3-100, 3-102 

S registers, 3-102 

V registers, 3-103 

semaphore registers, 3-104 
Registers 

Address (A), 2-4, 2-15 

Cluster Number (CLN), 2-14 

Current Instruction Parcel (CIP), 2-9 

Data Base Address, 2-14 

Data Limit Address, 2-14 

Exchange Address (XA), 2-13 

Exchange, see Exchange registers 

Flag (F), 2-12 

Instruction Base Address, 2-11 

Instruction Limit Address, 2-11 

Intermediate, 2-4 

Lower Instruction Parcel (LIP), 2-9 

Mode (M), 2-11 

Next Instruction Parcel (NIP), 2-9 

operating, see CPU operating registers 

Program Address, 2-8 

Program State (PS), 2-14 

Real-time Clock register, 2-15 

Scalar registers (S), 2-4, 2-15 

Semaphore, 2-15 

shared, 2-15 

Shared Address, 2-15 

Shared Scalar, 2-15 

Vector Length, 2-13 
Register values, 3-101 
Return jump, 3-120 
Return linkage, 3-28 
RTC register, see Real-time Clock register 



S - syndrome, 2-10 

S registers, see Scalar registers 
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SB registers, see Shared Address registers 
Scalar 

Add functional unit, 2-6, 3-58 

functional units, 2-5 

Logical functional unit, 2-6, 3-46, 3-51 

memory transfers, 3-4 

registers (S), 2-4 

Population/Parity/Leading Zero 
functional unit, 2-16, 3-37 

Shift functional unit, 2-6, 3-54, 3-57 
SECDED, 3-18 
Second Vector Logical unit enable/disable, 

2-12 
Second Vector Logical/Floating-point 

Multiply input, output data paths, 2-2 
Semaphore flag, 2-11 
Semaphore registers, 2-15, 3-23, 3-67, 

3-104, 3-106 
Shared 

address registers, 2-15 

registers, 2-15 

resources of CPU, 2-15 

scalar registers, 2-15 
Shift instructions, 3-100, 3-117 
Sign bit, 3-51, 3-58 

SM registers, see Semaphore registers 
Solid-state Storage Device, 1-6 
Special register values, 3-6 
ST registers, see Shared Scalar registers 
Status register, 3-68 
Stores, 3-107 

Symbolic instruction summary, 3-98, 3-99 
Symbolic notation, 3-6 

general syntax, 3-6 

special syntax form, 3-8 
Syntax, 3-6 

comment field, 3-8 

location field, 3-7 

operand field, 3-7 

register designators, 3-7 

result field, 3-7 
System 

basic organization, 1-1 

characteristics, 1-1 

configurations, see CRAY X-MP 
(model specifications) 

physical dimensions of, see CRAY X-MP 
(model specifications) 



Vector 

Add functional unit, 2-7, 3-85 
instructions, 3-19, 3-103, 3-106 
Length register, 2-13, 3-17, 3-34, 
3-73, 3-77, 3-84, 3-85, 3-87, 3-89, 
3-106 
logical functional units, 2-16, 3-76 
Mask, 3-95, 3-116 

register, 3-23, 3-68, 3-70, 3-94, 
3-106 
merge instruction, 3-23 
population, 3-119 

Population/Parity functional unit, 2-7 
processing, 2-1 
Shift functional unit, 2-7 
VL register, see Vector Length register 
VM register, see Vector Mask register 
VNU - vector not used, 2-12 



Word boundary, 3-1 
WS flag, 3-23 



XA register, see Exchange Add ess register 
XIOP, see Auxiliary I/O processor 



T registers, see Intermediate scalar 

registers 

Twos complement, 3-58, 3-84 

Twos complement integer arithmetic, 2-16 



Unconditional branch instruction, 3-26, 

3-27, 3-120 
Uncorrectable Memory Error Mode flag, 2-12 
Unnormalized floating-point value, 3-65 



V registers, see Vector registers 
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READER'S COMMENT FORM 

CRAY X-MP Computer Systems Functional Description Manual HR-3005 

Your reactions to this manual will help us provide you with better documentation. Please take a moment to 
check the spaces below, and use the blank space for additional comments. 

1) Your experience with computers: 0-1 year 1-5 years 5+ years 

2) Your experience with Cray computer systems: 0-1 year 1 -5 years 5+ years 

3) Your occupation: computer programmer non-computer professional 

other (please specify): 

4) How you used this manual: in a class as a tutorial or introduction as a reference guide 

for troubleshooting 
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5) Accuracy 8) Physical qualities (binding, printing) 

6) Completeness 9) Readability 

7) Organization 1 0) Amount and quality of examples 
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